黑马程序员技术交流社区
标题:
测试题迷惑
[打印本页]
作者:
熊永标
时间:
2012-12-24 17:54
标题:
测试题迷惑
现有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)]);
}
}
红色字体的地方是什么原理呀,看不懂,请问各位大虾帮忙指点.
作者:
许晓华
时间:
2012-12-25 00:42
http://bbs.itheima.com/forum.php ... mp;page=1#pid197804
这不就是我给的代码吗,在这个帖子里我解释过了啊。。。你去看看
作者:
熊永标
时间:
2012-12-25 09:30
是的,那请你给我说说红色字体的怎么回事呀,看不懂
作者:
许晓华
时间:
2012-12-25 09:42
熊永标 发表于 2012-12-25 09:30
是的,那请你给我说说红色字体的怎么回事呀,看不懂
帖子的8楼我做了推导了
作者:
清水
时间:
2012-12-26 15:23
用LinkedList 也只是单向的链表啊…… 这个跟数据结构没有关系。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2