首页 > 代码库 > 一些项目——约瑟夫问题
一些项目——约瑟夫问题
Description
n个人想玩残酷的死亡游戏,游戏规则如下: n个人进行编号,分别从1到n,排成一个圈,顺时针从1开始数到m,数到m的人被杀,剩下的人继续游戏,活到最后的一个人是胜利者。 请输出最后一个人的编号。
Input
输入n和m值。
Output
输出胜利者的编号。
Sample Input
5 3
Sample Output
4
代码
#include<iostream> using namespace std; int main() { int n,m,i,mi=0,k=0,p[10],y; cin>>n>>m; for(i=0; i<n; i++) p[i]=1; for(i=0; i<n; i++) { mi++; if(p[i]==0) mi--; if(mi==m) { p[i]=0; k++; mi=0; } if(k==n-1) { for(y=0; y<n; y++) if(p[y]==1) break; break; } if(i==n-1) i=-1; } cout<<y+1; return 0; }
一些项目——约瑟夫问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。