约瑟夫环的数组实现 __ 经典思考题原创解法.
来源:互联网 发布:淘宝几块钱的东西包邮 编辑:程序博客网 时间:2024/05/16 17:22
题目:
约瑟夫(Josephus)问题是由古罗马的史学家约瑟夫提出的,他参加并记录了公元66-70年犹太人反抗罗马的起义。约瑟夫作为一个将军,设法守住了裘达伯特城达47天之久,在城市沦陷之后,他和40名将士在附近的一个洞穴中避难。在哪里,将士们群情激奋并表示:要投降毋宁死。于是,约瑟夫建议每个人轮流杀死他旁边的人,而这个顺序是由抽签决定的。约瑟夫有预谋地抓到了最后一签并且做为洞穴中两个幸存者之一生存下来。
约瑟夫环问题的具体描述是:设有编号为1,2,......,n的n(n>0)个人围成一个圈,从第一个人开始报数,报到m时停止报数,报m的人出圈,再从他的下一个人起重新报数,报到m时停止报数,报m的出圈,......,如此下去,直到只剩下一人为止。当任意给定 n和 m后,设计算法求 n个人出圈的次序。
代码如下:#import <Foundation/Foundation.h>
//<span style="font-family: Arial, Helvetica, sans-serif;">SIZEONE 为数组大小 ,也就是存放一共有几个人, </span>//M为喊数字几就死一个人, 这里定义为3 也就是每当喊道 3 的那个人就死亡.#define SIZEONE 5#define M 3int main(int argc, const char * argv[]){
//数组初始化为1. 1代表此人活着. 0代表此人已死. int a[SIZEONE] = {1,1,1,1,1}; int count = SIZEONE , panduan = 1 , i = 1 ,j = 0; while( count != 1) { panduan = 1; if( a[j % SIZEONE] == 1) { if(i % M == 0) { a[j % SIZEONE] = 0; printf("%d ",j % SIZEONE); count --; j++; i = 1; } else { i++; j++; } } else { while ( panduan ) { if( a[j % SIZEONE] == 1) { if(i % M == 0) { a[j % SIZEONE] = 0; printf("%d ",j % SIZEONE); count --; i = 1; j++; panduan = 0; } else { i++; j++; panduan = 0; } } else { j++; } } } } return 0;}
0 0
- 约瑟夫环的数组实现 __ 经典思考题原创解法.
- 约瑟夫问题的数组解法
- 约瑟夫环数学解法和数组解法
- 约瑟夫环的解法
- 巧用数组实现约瑟夫环 (一道有意思的题目, 一个很巧的解法)
- 约瑟夫环的数组实现
- 约瑟夫环的数组实现
- 约瑟夫环的数学解法
- 约瑟夫环的数学解法
- 约瑟夫环的数学解法
- 关于约瑟夫环的解法
- 约瑟夫环的数学解法
- 约瑟夫环的暴力解法
- 约瑟夫环的数学解法
- 约瑟夫环,数三退一类问题(数组解法)
- 数组实现约瑟夫环
- 约瑟夫环数组实现
- 约瑟夫环数组实现
- Apple Rejected 回复备案
- OpenCV学习笔记(基于OpenCV 2.4)一:哈喽CV
- 将WCF服务发布到IIS上
- 解决 ubuntu 14.04 在笔记本上 和 nvidia 340, 346, 331 显示驱动 黑屏等问题, 如 T440s , T440p 等
- Python基础8--内置高阶函数
- 约瑟夫环的数组实现 __ 经典思考题原创解法.
- 树链剖分学习笔记
- Ioc容器初始化-bean资源定位(1)构造函数super(parent)
- inno setup
- animation动画的基础知识
- Oracle并行执行
- 云计算时代,对服务器的要求与改变
- Poj 1129 Channel Allocation(Dfs剪枝)
- 【Javascript】模块化编程笔记