题解 | 约瑟夫问题II

约瑟夫问题II

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

#include <vector>
class Joseph {
  public:
    int getResult(int n) {
        // write code here
        vector<int> people;
        for (int i = 1; i <= n; i++) people.emplace_back(i);
        int round = 1;
        int idx = 0;
        while (people.size() > 1) {
            vector<int> remain;
            int count = 1;
            for (int i = 0; i < people.size(); ++i) {
                int pos = (idx + i) % people.size();
                if (count == 1) {
                    remain.emplace_back(people[pos]);
                }
                ++count;
                if (count > round + 1) count = 1;
            }
            people = remain;
            idx = people.size() - 1;
            ++round;




        }
        return people.back();
    }
};

全部评论

相关推荐

07-15 12:15
门头沟学院 Java
点赞 评论 收藏
分享
弦五Strings:他之所以会举报你代课是因为在这种人眼里正常上课就是正义代课就是邪恶,典型二极管思维,处理方法就是私下沟通,你就说你自己家里经济困难或者家里父母生病什么之类的,需要去打工挣钱,用尽孝的正义对冲他认为的上课的正义,他可能就妥协了。
我的实习日记
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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