约瑟夫(Josephus)问题的实现

没想到学C++的第三天就遇到了这样猥琐的约瑟夫(Josephus)问题。

 

说n个人围坐成一圈,从1开始顺序编号;游戏开始,从第一个人开始由1到m循环报数,报到m的人退出圈外,问最后留下的那个人原来的序号。

 

而提示也只是什么计数器什么玩意的。想了半天因为还没有学C++的队列,所以逻辑上也理不清。就决定先用Java去做,所以本文章为Java类别。

 

好吧。我来看看简单难懂的提示。算了,对于本题并没有什么帮助,不用看了。下面是实现。import java.util.ArrayList;; public class josephus { /** * @param args */ public static void main(String[] args) { int m=5;//报到m的人退出圈外 int total=10;//总人数 int list_tmp[] = new int[total];//创建数组,我不知道java是否有动态一些的数组,比如不用分配空间什么的。这里1代表在场,0则代表出局。 int list[] = setCollect(list_tmp);//赋数组初始值,很奇怪我竟然以为java的数组可以一值多赋,写多js了。 int count=1;//计数器 String next = null; do{ //循环开始了 ArrayList join = getList(list);// 取得还在场的人员 int index =0; if(next!=null) index = join.indexOf(next);//确定现在的循环位置 int kill =index+m;//将被出局的人 if(kill >join.size())//从数组尾部外跳到其头部。 kill =kill %join.size(); String t = null; if(kill ==0)//判断是否正在尾部。 t = (String)join.get(kill ); else t = (String)join.get(kill -1); if(kill ==join.size()) kill =kill %join.size(); next = (String)join.get(kill );//记录下一次循环的位置 list[Integer.parseInt(t)]=0; //go out! count++;//计数+1 }while(count!=total);//如果到达总数跳出循环,最后一个被记录的人则是最后一个人。 System.out.println(Integer.parseInt(next)+1); } static ArrayList getList(int[] list){ ArrayList join = new ArrayList(); int y=0; for(int x=0;x

 

本来啊试着不大算用ArrayList。但最后因为我不知道生成动态数组的方法,而放弃了new int[].失落啊。

不管怎样反正是实现了。下面转换成c++就可以了。

额顺便一说,我没有找网上的其他实现方法,或许会有更简单的实现。但我还是觉得我自己想到的比较OK一些。毕竟是自己的玩意。

 

 

转载于:https://www.cnblogs.com/J2EEPLUS/archive/2009/09/09/2487816.html

你可能感兴趣的:(约瑟夫(Josephus)问题的实现)