C语言用循环单链表实现约瑟夫环

 更新时间:2021年10月28日 17:09:41   作者:东流长江水  
这篇文章主要为大家详细介绍了C语言用循环单链表实现约瑟夫环,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

用循环单链表实现约瑟夫环(c语言),供大家参考,具体内容如下

源代码如下,采用Dev编译通过,成功运行,默认数到三出局。

主函数:

main.c文件

#include <stdio.h>
#include "head.h"
#include "1.h"


int main() 
{
    Linklist L;
    int n;
    printf("请输入约瑟夫环中的人数:");
    scanf("%d",&n);
    Createlist(L,n);
    printf("创建的约瑟夫环为:\n");
    Listtrave(L,n);
    printf("依次出局的结果为:\n");
    Solution(L,n);
    return 0;
}

head.h文件:

#include "1.h"
#include <stdio.h>
#include <stdlib.h>



typedef int Elemtype;
typedef struct LNode{
    Elemtype data;
    struct LNode *next;
}LNode,*Linklist;

void Createlist(Linklist &L,int n)
{
    Linklist p,tail;
    L = (Linklist)malloc(sizeof(LNode));
    L->next = L;//先使其循环 
    p = L;
    p->data = 1;//创建首节点之后就先给首节点赋值,使得后面节点赋值的操作能够循环 
    tail = L;
    for(int i = 2;i <= n;i++)
    {
        p = (Linklist)malloc(sizeof(LNode));
        p->data = i;
        p->next = L;
        tail->next = p;
        tail = p;
    }
    printf("已生成一个长度为%d的约瑟夫环!\n",n); 
}
void Listtrave(Linklist L,int n)//遍历函数 
{
    Linklist p;
    p = L;
    for(int i = 1;i <= n;i++)
    {
        printf("%3d",p->data);
        p = p->next;
    }
    printf("\n");
}
int Solution(Linklist L,int n)
{
    Linklist p,s;
    p = L,s = L;
    int count = 1;
    while(L)
    {
        if(count != 3)
        {
            count++;p = p->next;//进行不等于3时的移位 
        }
        else
        {
            Linklist q;
            q = p;//用q保存p所指的位置,方便进行节点的删除 
            if(s->next->data == s->data)//当只有一个元素的时候 
            {
                printf("%3d\n",s->data);
                free(s);
                return OK;
            }
            else//当有两个及两个以上的元素的时候 
            {
                count = 1;//先将count重置为1
                printf("%3d",p->data);//再打印出出局的值 
                while(s->next != p) 
                {
                    s = s->next;//将s移位到p的前驱节点处 
                }
                p = p->next;//使p指向自己的下一个节点 
                s->next = p;//进行删除 
                free(q);
            }
        }
    }
}

1.h文件:

#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2

运行结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • OpenCV图像变换与处理实战方法记录

    OpenCV图像变换与处理实战方法记录

    这篇文章主要给大家介绍了关于OpenCV图像变换与处理实战的相关资料,包括重映射、缩放、旋转、颜色变换、边缘检测、高斯模糊、图像锐化和颜色反转等,通过实例分析详细解释了这些功能的实现原理和代码实现,需要的朋友可以参考下
    2024-12-12
  • C++ 读文件 将文件内容读入到字符串string中的方法

    C++ 读文件 将文件内容读入到字符串string中的方法

    今天小编就为大家分享一篇C++ 读文件 将文件内容读入到字符串string中的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • C语言宏定义#define的使用

    C语言宏定义#define的使用

    本文主要介绍了C语言宏定义#define的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C语言标准时间与秒单位相互转换

    C语言标准时间与秒单位相互转换

    这篇文章主要介绍了C语言标准时间与秒单位相互转换,秒单位与标准时间的转换方式,这份代码一般用在嵌入式单片机里比较多,比如:设置RTC时钟的时间,从RTC里读取秒单位时间后,需要转换成标准时间显示。下文分享需要的小伙伴可以参考一下
    2022-05-05
  • C++深度探索运算符重载和返回值优化

    C++深度探索运算符重载和返回值优化

    这篇文章主要介绍了C++运算符重载及编译器返回值优化,C++当中除了函数可以重载之外,其实运算符也是可以重载的,下面一起来详细了解吧
    2022-04-04
  • opencv利用矩形框选中某一区域并保存为新图片

    opencv利用矩形框选中某一区域并保存为新图片

    这篇文章主要为大家详细介绍了opencv利用矩形框选中某一区域并保存为新图片,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • C++与C的差异分析

    C++与C的差异分析

    这篇文章主要介绍了C++与C的差异分析,非常实用,需要的朋友可以参考下
    2014-08-08
  • C语言进阶教程之字符函数&字符串函数

    C语言进阶教程之字符函数&字符串函数

    C语言提供了丰富的字符串处理函数,可以对字符串进行输入、输出、合并、修改、比较、转换、复制、搜索等操作,下面这篇文章主要给大家介绍了关于C语言进阶教程之字符函数&字符串函数的相关资料,需要的朋友可以参考下
    2022-03-03
  • C/C++ 常用排序算法整理汇总分享

    C/C++ 常用排序算法整理汇总分享

    排序算法,就是如何使得记录按照要求排列的方法。排序算法在很多领域得到相当地重视,尤其是在大量数据的处理方面。一个优秀的算法可以节省大量的资源。本篇整理了c语言和c++的常用的排序算法,感兴趣的朋友可以参考下
    2021-06-06
  • 利用C++如何覆盖或删除指定位置的文件内容

    利用C++如何覆盖或删除指定位置的文件内容

    这篇文章主要给大家介绍了关于利用C++如何覆盖或删除指定位置的文件内容,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面跟着小编来一起学习学习吧。
    2017-08-08

最新评论