王道约瑟夫问题

#include<queue>
#include<cstdio>
using namespace std;
int main(){
int n, p , m;
while(true){
scanf(&quot;%d%d%d&quot;, &amp;n, &amp;p, &amp;m);
if(n == 0 &amp;&amp; p == 0 &amp;&amp; m == 0)
break;
}
queue<int> children;//队列中的元素是孩子的编号
for(int i = p, j = 0; j < n; ++j) {
//i用来记录 孩子编号 
//j用来记录已经遍历的孩子数量
children.push(i);
++i;
if(i > n){
i = 1;
}
}
//喊号过程
int num = 1;
while(true){
int cur = children.front();//cur是队首孩子的编号
children.pop();//喊完了,对手出队
if(num == m){
num = 1;
if(children.empty()){
printf(&quot;%d\n&quot;, cur);
break;
}else{
printf(&quot;%d\n&quot;, cur);
}

} else{
num = num + 1;
children.push(cur);
}

}
}
全部评论

相关推荐

用户64975461947315:这不很正常吗,2个月开实习证明,这个薪资也还算合理,深圳Java好多150不包吃不包住呢,而且也提前和你说了没有转正机会,现在贼多牛马公司骗你说毕业转正,你辛辛苦苦干了半年拿到毕业证,后面和你说没hc了😂
点赞 评论 收藏
分享
牛客10001:问就是六个月,全国可飞,给钱就干
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务