C++:利用C++语言实现约瑟夫环问题——利用函数嵌套+交互式实现n只猴子选猴王

简介: C++:利用C++语言实现约瑟夫环问题——利用函数嵌套+交互式实现n只猴子选猴王


目录

输出结果

实现代码


 

 

 

输出结果

 

 

 

实现代码

1. 
2. #include<iostream>    //头文件,识别大部分预处理命令,编译器才会合法识别后边使用的关键字
3. using namespace std;  //T1、命名空间,包括cout、cin、endl等
4. 
5. /*
6. 函数的嵌套:约瑟夫环问题——n只猴子选猴王的问题
7. }
8. */
9. 
10. 
11. //void可知,此函数没有使用返回值
12. void NextPosition(int &p,int tail)     //p是当前猴子的下标,执行函数之后得到下一个下标,tail表示最后一只猴子的下标
13. {
14.   p = (p < tail ? p + 1 : 0);        //暂时不考虑被淘汰掉的猴子
15. }
16. 
17. int NextNumber(int n, int tail)        //当前要报的数字、要报的最大数字
18. {
19.   return n == tail ? 1 : n + 1;      //
20. }
21. 
22. int MonkeyKing(int total, int cycle)   //参数输入猴子总数、所报最大数字
23. {
24.   bool*failure = new bool[total];         //建立total只猴子,为bool型,识别为是否被淘汰
25.   memset(failure, 0, sizeof(bool)*total);  //所有猴子初始化为0即false,即没有被淘汰
26.   //menset函数对数组进行归0,如果要统一赋其他值,可用for循环
27.   int position = total - 1;                //当前位置确定为最后一只猴子,
28.   int said = 0;                            //所报数字
29.   int i;
30.   int remained = total;                    //剩下的猴子个数
31.   while (remained > 1)
32.   {
33.     NextPosition(position,total-1);      //从当前猴子移动到下一只去
34.     if (failure[position] = false)       //假如该猴子尚未被淘汰
35.     {
36.       said = NextNumber(said, cycle);             //被轮到的猴子应该报到的数
37.       cout << "第" << position + 1 << "只猴子报" << said;
38.       if (said==cycle)                            //判断这只猴子报出的数是否为最大值,如果是,则要将其淘汰
39.       {
40.         failure[position] = true;               //将这只猴子淘汰出去
41.         cout << ",被淘汰。剩下" << --remained << "个\n";
42.       }
43.       else cout<<"。\n";
44. 
45.     }
46.   }
47.   //for (int i = 0; i < total; i++) if (failure[i] == false) break;  //T1、判断猴子是不是没有被汰淘
48.   for (i = 0; failure[i]; i++);                                  //T2、最简单的一句话
49.   delete []failure;
50.   return i;      //返回没有被淘汰的猴子下标
51. }
52. 
53. // void   return;     int return 0;
54. void main()
55. {
56.   cout << "Hello,world!欢迎来到《一个处女座程序猿》的博客!\n";
57.   int total,cycle;           //定义猴子总数、所报最大数字
58.   cout <<"请输入猴子总数:";          // << endl
59.   cin >> total;
60.   cout << "请输入猴子所报最大数:" ;
61.   cin >> cycle;
62.   cout << "第" << MonkeyKing(total, cycle)+1 <<"个猴子是猴王。\n";
63. 
64.   system("pause");
65.   return;
66. }

 


相关文章
|
3月前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
3月前
|
算法 C++
2022年第十三届蓝桥杯大赛C/C++语言B组省赛题解
2022年第十三届蓝桥杯大赛C/C++语言B组省赛题解
66 5
|
3月前
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
115 6
|
3月前
|
C++
C++ 多线程之线程管理函数
这篇文章介绍了C++中多线程编程的几个关键函数,包括获取线程ID的`get_id()`,延时函数`sleep_for()`,线程让步函数`yield()`,以及阻塞线程直到指定时间的`sleep_until()`。
52 0
|
3月前
|
编译器 C语言 C++
C++入门6——模板(泛型编程、函数模板、类模板)
C++入门6——模板(泛型编程、函数模板、类模板)
76 0
C++入门6——模板(泛型编程、函数模板、类模板)
|
3月前
|
存储 编译器 C语言
深入计算机语言之C++:类与对象(上)
深入计算机语言之C++:类与对象(上)
|
3月前
|
存储 分布式计算 编译器
深入计算机语言之C++:C到C++的过度-2
深入计算机语言之C++:C到C++的过度-2
|
3月前
|
编译器 Linux C语言
深入计算机语言之C++:C到C++的过度-1
深入计算机语言之C++:C到C++的过度-1
|
3天前
|
C++ 芯片
【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
声明一个简单的Computer类,含有数据成员芯片(cpu)、内存(ram)、光驱(cdrom)等等,以及两个公有成员函数run、stop。只能在类的内部访问。这是一种数据隐藏的机制,用于保护类的数据不被外部随意修改。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。成员可以在派生类(继承该类的子类)中访问。成员,在类的外部不能直接访问。可以在类的外部直接访问。为了完成本关任务,你需要掌握。
35 18
|
3天前
|
存储 编译器 数据安全/隐私保护
【C++面向对象——类与对象】CPU类(头歌实践教学平台习题)【合集】
声明一个CPU类,包含等级(rank)、频率(frequency)、电压(voltage)等属性,以及两个公有成员函数run、stop。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。​ 相关知识 类的声明和使用。 类的声明和对象的声明。 构造函数和析构函数的执行。 一、类的声明和使用 1.类的声明基础 在C++中,类是创建对象的蓝图。类的声明定义了类的成员,包括数据成员(变量)和成员函数(方法)。一个简单的类声明示例如下: classMyClass{ public: int
30 13