java约瑟夫出圈问题 10

用数组实现约瑟夫出圈问题。n个人排成一圈,从第一个人开始报数,从1开始报,报到m的人出圈,剩下的人继续开始从1报数,直到所有的人都出圈为止。对于给定的n、m,编写程序求出... 用数组实现约瑟夫出圈问题。 n个人排成一圈,从第一个人开始报数,从1开始报,报到m的人出圈,剩下的人继续开始从1报数,直到所有的人都出圈为止。对于

给定的n、m,编写程序求出所有人的出圈顺序。

分析过程如下:

首先可以肯定的是我们需要用一个数组来存储这n个人,n是通过控制台输入获得的,用来确定数组的长度,数组的每个元素都给赋值,
从第一个人开始报数,从1开始报,报到m的人出圈,(出圈的处理操作为:首先把这个数用一个临时变量存储起来,然后把这个数之后的数逐个往前移一位,移完后把出圈的这个

数存放到数组的最后一位上。)出圈后仍然从这个位子从新报数(从1开始报数),下一个报到m的人又进行出圈处理,出圈后仍然从这个位子从新报数,(出过圈的数不进行报数

,但是在其他数出圈的时候仍然要执行移位的操作)。这样一直执行下去,直到所有的人都出圈过为止。
代码实现过程
n:元素个数
m:数到则出圈的数
count:用来报数
t:用来记录出圈元素个数
int count = 0, t = 0;
while (t < n) {//用于控制所有元素都能出圈,有元素没有出圈就继续循环
for (int i = 0; i < ren.length-t; i++) {//对元素进行遍历(注意控制边界)
count++;//每遍历一个元素就count+1,相当于报数
if (count == m) {//当报到m时进行下面的出圈操作
t++;//记录出圈元素个数
String str= ren[i];//存储当前元素
for (int j = i; j < ren.length - 1; j++) {
ren[j] = ren[j + 1];//当前元素之后的所有元素都往前移一位。
}
ren[ren.length - 1] = str;//把出圈的元素放到数组的最后位置上
count = 0;//count赋0值,保证从头开始报数。
i--;//作用是保证仍然在当前位置进行报数。
}
}
}
展开
 我来答
浅处268
2015-03-29 · TA获得超过295个赞
知道答主
回答量:34
采纳率:100%
帮助的人:10.2万
展开全部
public class YueSeFuCircle
{
  public static void main(String[] args)
  {
  int n = 100;//总共多少人
  int kill = 3;//要出圈的数字
  int winner = 0;

for (int i = 2; i <= n; i++)
  {
  winner = (winner + kill) % i;
  System.out.println(winner);
  }
   System.out.println("Winner is:" + (winner + 1));
   }
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
推荐于2018-04-23
展开全部
代码实现过程
n:元素个数
m:数到则出圈的数
count:用来报数
t:用来记录出圈元素个数
int count = 0, t = 0;
while (t < n) {//用于控制所有元素都能出圈,有元素没有出圈就继续循环
for (int i = 0; i < ren.length-t; i++) {//对元素进行遍历(注意控制边界)
count++;//每遍历一个元素就count+1,相当于报数
if (count == m) {//当报到m时进行下面的出圈操作
t++;//记录出圈元素个数
给定的n、m,编写程序求出所有人的出圈顺序。

分析过程如下:

首先可以肯定的是我们需要用一个数组来存储这n个人,n是通过控制台输入获得的,用来确定数组的长度,数组的每个元素都给赋值,
从第一个人开始报数,从1开始报,报到m的人出圈,(出圈的处理操作为:首先把这个数用一个临时变量存储起来,然后把这个数之后的数逐个往前移一位,移完后把出圈的这个

数存放到数组的最后一位上。)出圈后仍然从这个位子从新报数(从1开始报数),下一个报到m的人又进行出圈处理,出圈后仍然从这个位子从新报数,(出过圈的数不进行报数 String str= ren[i];//存储当前元素
for (int j = i; j < ren.length - 1; j++) {
ren[j] = ren[j + 1];//当前元素之后的所有元素都往前移一位。
}
ren[ren.length - 1] = str;//把出圈的元素放到数组的最后位置上
count = 0;//count赋0值,保证从头开始报数。
i--;//作用是保证仍然在当前位置进行报数。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式