孩子们的游戏(约瑟夫环)

孩子们的游戏(圆圈中最后剩下的数)

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;
    }
};
全部评论

相关推荐

昨天 13:52
武汉大学 golang
点赞 评论 收藏
分享
头像
05-26 10:24
门头沟学院 Java
qq乃乃好喝到咩噗茶:其实是对的,线上面试容易被人当野怪刷了
找工作时遇到的神仙HR
点赞 评论 收藏
分享
05-29 22:11
门头沟学院 Java
Elastic90:抛开学历造假不谈,这公司的招聘需求也挺怪的,Java开发还要求你有图文识别、移动端开发和c++的经验,有点逆天了。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务