服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C++约瑟夫环问题详解

C++约瑟夫环问题详解

2022-08-15 10:10夏天的峰没有风 C/C++

大家好,本篇文章主要讲的是C++约瑟夫环问题详解 ,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览

题目如下:

有一家公司,这个公司有一位老板和13名程序员,每天下班前老板都会组织他们玩一次游戏,游戏的胜利者可以不加班,失败者需要加班2小时。游戏规则如下: 一张圆桌共有13个座位,从1到13编号,游戏开始前老板会说出今天开始报数的座位编号start和淘汰序号k。 然后13名程序员开始抢位置,每个位置只能容纳一程序员,每个程序员必须选择一个座位。 座位号为start的程序员从1开始报数,按如图所示方向依次报数。每次报数为k的程序员淘汰并离开座位去加班,其他人继续游戏,直到剩下最后一人潇洒离去。

C++约瑟夫环问题详解

有一位非常聪明的程序员,每次在老板说出start和k的瞬间,就能立即选好座位并且获胜,所以他从来没有加过班,其他程序员都非常羡慕他,问他制胜法宝,只见他缓缓的打开了一个名为IAMGOD的.c文件,大家都露出崇拜的目光。

今天,你就是这个聪明的程序员,请完善IAMGOD.c文件内容。

根据提示,在右侧编辑器完善IAMGOD.c文件内容,找到可以不加班的座位号。

输入:start k

输出:所选的座位编号i

示例1-输入:2 3

           输出:13

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#include<stdio.h>
#include<malloc.h>
 
//创建结构体
typedef struct Node{
    int data;
    struct Node* next;
} NODE;
 
//创建新结点和插入结点
void insert(NODE* head)
{
    int i;
    NODE* tail = head;
    
    //对每一个结点进行编号,依次编号为1、2、3......13
    for(i = 2; i <= 13; i++)
    {
        NODE* newnode;
        newnode = (NODE*)malloc(sizeof(NODE));
        newnode->data = i;
        
        //尾插法连接链表
        newnode->next = NULL;
        tail->next =  newnode;
        tail = newnode;
    }
    
    /*
    这段语句用来打印链表,检测链表是否正确连接的
    NODE* pmove = head;
    while(pmove != NULL)
    {
      printf("%d->",pmove->data);
      pmove = pmove->next;
    }
    */
     
     tail->next = head; //将尾结点连接到头结点上,形成一个环
}
 
void serch(NODE* head)
{
     int start_data,i,k;
    NODE* start = head;
    scanf("%d%d", &start_data, &k);
    
    //移动到第start_data结点,并将此结点当成1号结点
    for(i = 2; i <= start_data; i++)
    {
        start = start -> next;
    }
    
    NODE* front; //front表示第k个结点的前一个结点
    while(start->next != NULL)
    {
      int j;
      for(j = 2; j <= k; j++)
      {
        front = start; //先让front移动到当前结点,然后当前结点往下移动,就形成一前一后的效果
        start = start->next; //移动结点
      }
        
        front->next = start->next; //将第k个结点的上一个结点连接到它的下一个结点上
        
        free(start);//删除指定结点
        start = front->next;//更新start的位置,也就是1号
        
        //当第k个仍是本身,即只剩下了一个结点,跳出循环
        if(start->data == (start->next)->data)
         break;
    }  
    printf("%d",start->data);
}
 
int main()
{
   //创建链表
    NODE* head;
    head = (NODE*)malloc(sizeof(NODE));
    head->data = 1;
    head->next = NULL;
    
    
    //创建新结点和连接结点
    insert(head);
    
    //查找第k个结点并且将其删除。
    serch(head);
    return 0;
}

到此这篇关于C++约瑟夫环问题详解 的文章就介绍到这了,更多相关C++约瑟夫环内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_29992017/article/details/122421128

延伸 · 阅读

精彩推荐
  • C/C++获取当前系统本地时间,精确到毫秒的实例

    获取当前系统本地时间,精确到毫秒的实例

    下面小编就为大家带来一篇获取当前系统本地时间,精确到毫秒的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看...

    独孤酷酷6852021-06-09
  • C/C++C++多线程中的锁和条件变量使用教程

    C++多线程中的锁和条件变量使用教程

    这篇文章主要介绍了C++多线程中的锁和条件变量使用,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下...

    Agang''''s blog6762021-07-10
  • C/C++详解c++11新特性之模板的改进

    详解c++11新特性之模板的改进

    这篇文章主要介绍了详解c++11新特性之模板的改进,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    zx8462021-09-03
  • C/C++用typedef定义类型详细总结

    用typedef定义类型详细总结

    用typedef可以声明各种类型名,但不能用来定义变量,用typedef可以声明数组类型、字符串类型、使用比较方便...

    C语言教程网11522021-01-07
  • C/C++C经典冒泡排序法实现代码

    C经典冒泡排序法实现代码

    这篇文章主要介绍了C经典冒泡排序法实现代码,需要的朋友可以参考下...

    C语言教程网6832021-01-14
  • C/C++c++ 动态内存分配相关总结

    c++ 动态内存分配相关总结

    这篇文章主要介绍了c++ 动态内存分配相关的相关资料,帮助大家更好的理解和学习和使用c++,感兴趣的朋友可以了解下...

    流星斩月8802021-10-25
  • C/C++C语言深入讲解之从函数栈帧角度理解return关键字

    C语言深入讲解之从函数栈帧角度理解return关键字

    在C语言中,一般情况下函数的返回值是通过函数中的return语句来实现的,每调用一次return语句只能从函数中返回一个值,这篇文章主要给大家介绍了关于C语言...

    Bitdancing5982022-01-11
  • C/C++C语言实现三子棋小游戏(vs2013多文件)

    C语言实现三子棋小游戏(vs2013多文件)

    这篇文章主要为大家详细介绍了C语言实现三子棋小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    m0_531463286622021-11-15