约瑟夫(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<list.length;x++){ if(list[x]!=0){ join.add(String.valueOf(x)); y++; } } return join; } static int[] setCollect(int[] list){ int y=1; for(int x=0;x<list.length;x++){ list[x]=y; } return list; } }  

 

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

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

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

 

 

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值