现有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)]);
}
}
红色字体的地方是什么原理呀,看不懂,请问各位大虾帮忙指点. |