题解 | 约瑟夫环

约瑟夫环

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

#include <iostream>
#include <vector>
using namespace std;

bool isok(const vector<int>& a){
    int count=0;
    for(int as:a){
        if(as==1){
            count++;
        }
    }
        return count==1;
}

int main() {
    int n,k,m;
    cin>>n>>k>>m;
    vector<int> a(n,1);
    int s,rem=m;
    while(!isok(a)){
    m=rem;
    for(int i=0;i<m;i++){
    if(a[(k+i)%n]==0){
        m++;
    }}
    s=(k+m-1)%n;
    a[s]=0;
    k=(s+1)%n;
    }
    for(int i=0;i<n;i++){
        if(a[i]==1){
            cout<<i<<endl;
        }
    }


    }
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

09-22 09:42
门头沟学院 Java
牛客37185681...:马德,我感觉这是我面过最恶心的公司,一面是两个女hr,说什么实习前几个月属于试用期,试用期过了才能转成正式实习生,我***笑了,问待遇就是不说,问能不能接受全栈,沙币公司
如果可以选,你最想去哪家...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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