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

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

https://www.nowcoder.com/practice/f78a359491e64a50bce2d89cff857eb6

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param n int整型 
     * @param m int整型 
     * @return int整型
     */
    int LastRemaining_Solution(int n, int m) {
        vector<int> nums(n);
        for(int i = 0 ; i < n ; i++){
            nums[i] = i;
        }
        int cnt = 0;
        int index = 0;
        while(nums.size()!=1){
            int wipe_index = (index + m - 1) % nums.size();
            nums.erase(nums.begin() + wipe_index);
            index = wipe_index % nums.size();
        }
        return nums[0];
    }
};

全部评论
很完美的一遍过:直接模拟,用vector存储编号,然后一直删除其中的元素,直到size为1.删除逻辑为:初始化下标为0,然后查找删除的下标为 (0 + m -1 ) % size , 然后用erase删除,更新起始下标为删除下标%size,即可
点赞 回复 分享
发布于 04-18 11:29 上海

相关推荐

不愿透露姓名的神秘牛友
03-29 08:32
点赞 评论 收藏
分享
Cherrycola01:0实习 0项目 约等于啥也没有啊 哥们儿这简历认真的吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务