题解 | 约瑟夫环

约瑟夫环

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

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

int main() {
    int n,k,m;
    cin>>n>>k>>m;
    vector<int>b(n,1);
    int m0=m;
    for(int j=1;j<=n-1;j++){
        while (m0>0){
           if(b[k]==1){
                 m0--;
           }
           
             k=(k+1)%n;
           
        }
          if(k==0){
            b[n-1]=0;
          }
          else{
            b[k-1]=0;
          }
          m0=m;
    }
    for(int w=0;w<n;w++){
        if(b[w]==1){ 
            cout<<w;
            break;
        }
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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