黑马程序员技术交流社区
标题:
经典算法
[打印本页]
作者:
ciying88
时间:
2017-3-14 16:51
标题:
经典算法
500个小孩围成一圈,从第一个开始报数:1,2,3,1,2,3,1,2,3,……每次报3的小孩退出
问最后剩下的那个小孩,在以前500人里是第几个???
public static void main(String[] args) {
int n = 500, m = 3;
int index = 0;
for (int i = 2; i <= n; i++) {
index = (index + m) % i;
}
System.out.println(index + 1);
}
作者:
zhao543
时间:
2017-3-14 19:31
练练试试
作者:
海天酱油
时间:
2017-3-15 00:05
这也可以?
作者:
mrwalker
时间:
2017-3-15 09:11
表示看不懂
作者:
明明凯凯归归
时间:
2017-3-15 15:07
这个逆推牛!但我想到的是index从2开始,循环内部是数列递推关系,通过最后一个死去的人向左逆推第0个死去的人相对于最后一个活人的位置index,最终打印index-1,通过算式转换为那个结果。
作者:
生无可恋
时间:
2017-3-16 19:14
这个蛮6的呀,自己想想看,有没有别的思路
作者:
yewei
时间:
2017-3-16 20:22
好复杂的算法
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2