A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 熊永标 中级黑马   /  2012-12-24 17:54  /  1506 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

      现有50个数字,放在一个数组中,a[0],a[1],a[2],a[3]..............a[49],将他们绕城一个圈排列,从1开始,每到第3个数字,即去除,这样循环往复,一直到最后,现在要求通过一段程序,来求出最后一个剩下的数字是多少?
//此题为经典的约瑟夫环问题,没有用LinkedList
public class x
{
        static int josephus(int N,int K)
        {
            int alive=0;//1个人的话,最后活下的编号是0号
            for (int i=2;i<=N;i++)//从第2个人开始循环
                alive=(alive+K)%i;           
               return alive;
        }
        public static void main(String []args)
        {
               
                Integer[]arr=new Integer[50];
                for(int i=0;i<50;i++)
                {
                        arr=i+1;
                }
                System.out.println(arr[josephus(50,3)]);
        }
}
红色字体的地方是什么原理呀,看不懂,请问各位大虾帮忙指点.

评分

参与人数 1技术分 +1 收起 理由
邵天强 + 1 神马都是浮云

查看全部评分

4 个回复

倒序浏览
http://bbs.itheima.com/forum.php ... mp;page=1#pid197804
这不就是我给的代码吗,在这个帖子里我解释过了啊。。。你去看看
回复 使用道具 举报
是的,那请你给我说说红色字体的怎么回事呀,看不懂
回复 使用道具 举报
熊永标 发表于 2012-12-25 09:30
是的,那请你给我说说红色字体的怎么回事呀,看不懂

帖子的8楼我做了推导了
回复 使用道具 举报
用LinkedList  也只是单向的链表啊…… 这个跟数据结构没有关系。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马