- 浏览: 38212 次
- 性别:
- 来自: 北京
文章分类
最新评论
著名的约瑟夫环问题详解
问题概述:
例如:n = 9, k = 1, m = 5
【解答】
出局人的顺序为5, 1, 7, 4, 3, 6, 9, 2, 8。
package wish25MethodNO1;
public class JosephusQuestion {
public static void main(String[] args) {
boolean[] bool = new boolean[600];//定义一个600人的布尔类型的数组用于标示所有人的状态,在圈里的都置为true否则为false
for(int i = 0;i<bool.length;i++) {
bool[i]=true;//开始时600人形成一个圈,都在圈里,初始化为true
}
int countArrayLength = bool.length;//定义一个整形的变量countArrayLength用来统计在圈里的人数
int index = 0;//定义一个整形index用来记录在圈里人的编号,即数组的下标
int count = 0;//定义一个计数器(统计圈里人报的数(1,2,3),当遇到3便重新置为0),用于圈里人的报数
while(countArrayLength>1) {//当圈里只有一个人的时候会停止循环
if(bool[index]==true) {//圈里要有人才能开始报数
count++;//计数器自加1
if(count == 3) {//如果报到3这个数(就出列)
count = 0;//计数器归0
bool[index]=false;//报到3的人出列
countArrayLength--;//圈里的人数自减1
}
}
index++;//在圈里的人依次循环报数
if(index == bool.length) {//当编号为数组长度时(应置为0,否则会报ArrayIndexOutOfBoundsException异常)
index = 0;//置为0
}
}
System.out.print("最后一个出列的人原来的编号是:");
for(int i = 0;i<bool.length;i++) {//经过上面的筛除后,留下的便是要找的
if(bool[i]==true) {
System.out.println(i);
}
}
}
}
方法二:用面向对象的思想来解决问题
在同一个包里新建了3个类,代码如下:(见下一篇)
发表评论
-
String中的小问题2
2010-10-25 14:24 68//题目;收集顾客反馈意见信息(用户输入的自己姓名、联系方 ... -
斐波那契数列
2010-10-25 14:23 160/**题目:斐波那契数列 * 求fibonacci数列 ... -
String中的小问题
2010-10-25 14:22 90/**题目1: * 给定一个字符串"Aaaa ... -
四种操作xml的方式: SAX, DOM, JDOM , DOM4J的比较
2010-10-25 13:43 57四种操作xml的方式: SAX, DOM, JDOM ... -
用Dom4j解析XML及中文问题
2010-10-25 13:42 301用Dom4j解析XML及中文问题(转载) ... -
Dom4j的使用(转至CSDN)
2010-10-25 13:32 74Dom4j 使用简介 DOM4J ... -
JSON入门二
2010-10-25 13:29 652JSON 的真正价值 正如在上一篇文章 中所描 ... -
JSON入门一
2010-10-25 13:27 694在异步应用程序中发送和接收信息时,可以选择以纯文本和 X ... -
a href="#" 与 a href="javascript:void(0)" 的区别(转)
2010-10-25 13:25 773a href="#" 与 a h ... -
浅谈java中的冒泡排序法
2010-10-25 13:13 1852冒泡排序法 冒泡 ... -
浅谈java中的选择排序法
2010-10-25 13:12 1401选择排序法 选择 ... -
C语言中的二分查找(折半查找)
2010-10-25 13:11 2874为了提高查找效率,在一个数组中查找某个数据是否存在时,可 ... -
约瑟夫环2
2010-10-25 13:06 210方法二:用面向对象的思想来解决问题 在同一个包里新建 ... -
Java中实现对象比较的几个相关概念
2010-10-25 12:54 782在Java中实现对象比较的几个相关概念(转) 一、跟对象 ...
相关推荐
约瑟夫环代码约瑟夫环代码约瑟夫环代码约瑟夫环代码约瑟夫环代码约瑟夫环代码
单链表解决约瑟夫环问题
本程序主要是以建立单循环链表的形式,利用单向循环链表存储结构模拟此过程,建立起一个约瑟夫环,然后根据之前创立的结点,输入结点里的一些数据,程序有主函数开始,首先,提示输入创建约瑟夫环环数以及每个环上所...
约瑟夫环~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
用C语言实现约瑟夫环,适合初学者学习 用C语言实现约瑟夫环,适合初学者学习 用C语言实现约瑟夫环,适合初学者学习 用C语言实现约瑟夫环,适合初学者学习 用C语言实现约瑟夫环,适合初学者学习 用C语言实现约瑟夫环...
约瑟夫环c单链表问题描述:约瑟夫问题的一种描述是:编号为1,2,…,n的n个人按顺时针方向围坐一圈,每人持一个密码(正整数)。一开始任选一个正整数作为报数上限值m,从第一个人开始按顺时针方向自1开始顺序报数...
c# 约瑟夫环问题算法 的实现。
用vc6.0环境实现的约瑟夫环的上机实验报告
约瑟夫环的例子,约瑟夫环的例子 约瑟夫环的例子,约瑟夫环的例子
用顺序表表示约瑟夫环,其中密码相同,即为静态存储约瑟夫环的内容
采用单向环表实现约瑟夫环。请按以下要求编程实现:①从键盘输入整数m,通过create函数生成一个具有m个结点的单向环表。环表中的结点编号依次为1,2,……,m。②从键盘输入整数s(1<=s<=m)和n,从环表的第s...
大二时数据结构课上做的一个约瑟夫环,带有图形界面,开发语言是c++
用单链表解决约瑟夫环问题,数据结构实验报告。约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人...
使用c语言中的循环链表及结构体实现约瑟夫环问题
在VC++6.0环境下C语言编程实现,实现了约瑟夫环的问题。
这个约瑟夫环代码简单易懂,附解释,是在老师的辅导下完成的,相信大家看了就会懂
多种方法解决约瑟夫环问题,1.顺序表2.循环链表3.循环队列4.普通一位数组
约瑟夫环(Josephus)问题是由古罗马的史学家约瑟夫(Josephus)提出的,他参加并记录了公元66—70年犹太人反抗罗马的起义。约瑟夫作为一个将军,设法守住了裘达伯特城达47天之久,在城市沦陷之后,他和40名死硬的...
数据结构实习报告,约瑟夫环,内附源代码,有注释。
约瑟夫环(Joseph)问题的一种描述是:编号为1、2、3……n的n个人按照顺时针方向围坐一圈,每人持有一个密码(正整数)。一开始任选一个正整数作为报数的上限值m,从第一个人开始按照顺时针的方向自1开始顺序报数,...