约瑟夫(Josephus)问题的实现

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

 

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

 

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

 

好吧。我来看看简单难懂的提示。算了,对于本题并没有什么帮助,不用看了。下面是实现。 

 

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

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

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

 

 

posted @ 2009-09-09 14:05  j2ee技术  阅读(309)  评论(0编辑  收藏  举报