孩子们的游戏(约瑟夫环)
孩子们的游戏(圆圈中最后剩下的数)
http://www.nowcoder.com/questionTerminal/f78a359491e64a50bce2d89cff857eb6
1.可以用队列模拟出队过程
2.数学方法递推
0 1 2 3 4 共5个数 输入3 ,则f(5,3)代表其结果
第一个出去的是2,此时队变成 3 4 0 1 共四个数输入还是3
假如我们将3 4 0 1 替换成 0 1 2 3 则变成求4个人输入为3 的问题 即f(4,3)
总结为f(5,3) = (f(4,3)+3)%5
即通用表达式为f(n)=(f(n-1)+m)%n
class Solution {
public:
int LastRemaining_Solution(int n, int m) {
if(!n)return -1;
int index = 0;
for( int i = 2; i<=n;i++){
index = (index + m)%i;
}
return index;
}
};
海康威视公司福利 1377人发布
查看23道真题和解析