每日一题解决数据结构——约瑟夫环问题

问题简述:

约瑟夫问题的源头完全可以命名为“自杀游戏”。本着和谐友爱和追求本质的目的,我们把问题描述如下:

  • 现有T个人围成一桌坐下,编号从1到T,从编号为1的人开始报数。
  • 报数也从1开始,报到M的人离席,从离席者的下一位在座成员开始,继续从1开始报数。
  • 复现这个过程(各成员的离席次序),或者求最后一个在座的成员编号。

 

代码展示:

#include<stdio.h>
#include<stdlib.h>
//WuXinYu
typedef struct Node
{
    int data;
    struct Node* next;
}Node;
//创建结构体变量

Node* Create(){
     Node* head;
     head = (Node*)malloc(sizeof(Node));
     if (head == NULL) {
         exit(1);
     }
     head->next = NULL;
     return head;
}
//创建链表

int main(){
    //Double Xin
    int Pnum,Kill_num,i;
    Node* tail,* p,* q;
    Node* head = Create();

    printf("请输入总人数:");
    scanf("%d",&Pnum);
    printf("请输入一个数字并让身处该数字的人go to die:");
    scanf("%d",&Kill_num);
    //完成输入总人数以及第几个人go to die

    if(Pnum == 0 || Kill_num == 0){
        return 0;
    }
    //判断是否存在不可能的情况,完备性检验。
    else{
        tail = head;//空链表让head指向tail
        for (i = 0; i < Pnum; i++)
        {
            p = (Node*)malloc(sizeof(Node));
            //建立一个插入节点p            
            if(p == NULL){
                printf("申请失败");
                exit(1);
            }//完备性检验

            p -> data = i+1;    
            tail -> next = p;
            p -> next = head -> next;
            tail = p;
            //构建循环链表并且输入数据
        }
        p = head -> next;
        q = tail;
        i = 1;
    }       //以上为数据输入部分

    while (p != q) //判断是否重合,重合则存在一个数据
    {
        if(i == Kill_num){
            q -> next = p -> next;
            printf("%d\t",p -> data);
            free(p);
            p = q -> next;
            i = 1;
        }/*WuXinYu*/
        else{
            q = p;
            p = q -> next;
            i++;
        }
    }

    printf("\n");
    printf("幸运儿是%d",p -> data);
    return 0;
}

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

欣代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值