有N个人围成一圈,第一个人从1开始报数,报到M的人出列,求最后一个出列的人。
2011-08-12 14:54
260 查看
这是一个约瑟夫环问题,下面给出了java实现的例子:
Java代码
package com.juziku;
import java.util.Arrays;
/**
* n个人围成一圈,报到m的人出列
* @author sunlightcs
* 2011-3-8
* http://hi.juziku.com/sunlightcs/
*/
public class Queue {
public static
void main(String[] args) {
queue(10, 3);
}
/**
* 最后出队的人
* @param total 总的人数
* @param num 第几号出队
*/
public static
void queue(int total,
int num){
//定义一个数组,true表示没有出队列的,false表示已经出队列的
boolean []arr = new
boolean[total];
Arrays.fill(arr, true);
//移动变量,如:1 2 3 1 2 3 1 2
int next = 1;
//数组下标
int index = 0;
//剩下的人数
int count = total;
//如果剩下的人数为1人时,停止报数
while(count>1){
if(arr[index] ==
true){
if(next == 3){
arr[index] = false;
//剩下的人数减1
--count;
//移动变量复位,从1开始报数
next = 1;
System.out.println("依次出列的人为:"+(index+1));
}else{
++next;
}
}
++index;
if(index == total){
//数组下标复位,从0开始新重遍历
index = 0;
}
}
for(int i=0; i<total; i++){
if(arr[i] == true){
System.out.println("最后出列的人为:"+(i+1));
}
}
}
}
Java代码
package com.juziku;
import java.util.Arrays;
/**
* n个人围成一圈,报到m的人出列
* @author sunlightcs
* 2011-3-8
* http://hi.juziku.com/sunlightcs/
*/
public class Queue {
public static
void main(String[] args) {
queue(10, 3);
}
/**
* 最后出队的人
* @param total 总的人数
* @param num 第几号出队
*/
public static
void queue(int total,
int num){
//定义一个数组,true表示没有出队列的,false表示已经出队列的
boolean []arr = new
boolean[total];
Arrays.fill(arr, true);
//移动变量,如:1 2 3 1 2 3 1 2
int next = 1;
//数组下标
int index = 0;
//剩下的人数
int count = total;
//如果剩下的人数为1人时,停止报数
while(count>1){
if(arr[index] ==
true){
if(next == 3){
arr[index] = false;
//剩下的人数减1
--count;
//移动变量复位,从1开始报数
next = 1;
System.out.println("依次出列的人为:"+(index+1));
}else{
++next;
}
}
++index;
if(index == total){
//数组下标复位,从0开始新重遍历
index = 0;
}
}
for(int i=0; i<total; i++){
if(arr[i] == true){
System.out.println("最后出列的人为:"+(i+1));
}
}
}
}
相关文章推荐
- 有N个人围成一圈,第一个人从1开始报数,报到M的人出列,求最后一个出列的人
- js解决N个人围成一圈,第一个人从1开始报数,报到M的人出列,求最后一个出列的人的编号。
- C语言:有n个人围成一圈,顺序排号,从第一个人开始报数(从1到3),凡报到3的人退出圈子,问最后一个留下的是原来的第几号的那位?
- Java 写有n个人围成一圈,顺序排号,从第一个人开始报数(从1~3报数), 凡报到3的人退出圈子,问最后留下的人原来排在第几号。
- Java编程之有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子
- N个人围成一环形圈,第一个人从1开始报数,报道M的人出列,直到最后一个同学
- 有n个人围成一圈,顺序排号。从第一个人开始报数(从1~3报数),凡报到3的人退出圈子,问最后留下的人原来是第几号
- 有n个人围成一圈,顺序排号,从第一个人开始报数(从1~3报数),凡报到3的人退出圈子,问最后留下的人原来排在第几号。
- 有n个人围成一圈,顺序编号,从第一个人开始报数,凡报到3的人出圈,编写程序,问最后留下的是原来第几号的那位?
- 当当笔试题(有n个人成一圈,顺序排号(编号为1到n),从第一个人开始报数1到3报数),凡报到3的人出圈子,从下个人开始继续报数,直到最后一个人,问最后留下在是第几号?)
- 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
- 有n个人围成一圈编号1~n,顺序排好,从第一个人开始1到3报数,凡是报到3的人退出圈子,C语言编程出圈顺序
- C语言 约瑟夫圈问题:N个人围成一圈,从第一个人开始按顺序报数并编号1,2,3,……N,然后开始从第一个人转圈报数,凡是报到3的退出圈子。则剩下的最后一个人编号是多少。
- 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数)凡报到3的人退出圈子问最后留下1个人的是原来第几号的那位。
- java 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
- 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位
- n个人围成一圈,从第一个人开始123报数,报到3的离开,问最后剩下的人是第几个?
- 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
- 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那个人。
- Java编程之有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子