编号为1…N的N个小朋友玩游戏,他们按编号顺时针围成一圈,从第一个人开始按逆时针次序报数,报到第M个人出列;然后再从下个人开始按顺时针次序报数,报到第K个人出列;再从下一个人开始按逆时针次序报数,报到第M个人出列;再从下个人开始按顺时针次序报数,报到第K个人出列……以此类推不断循环,直至最后一人出列。请编写程序按顺序输出出列人的编号。
输入格式:
输入为3个正整数,分别表示N、M、K,均不超过1000。
输出格式:
输出为一行整数,为出列人的编号。每个整数后一个空格。
输入样例:
6 3 5
输出样例:
5 3 1 2 4 6
#include <bits/stdc++.h>
using namespace std;
int main() {
int n,m,k,flag = -1;
vector<int > a;
cin>>n>>m>>k;
m %= n;
int len = n;
k %= n;
for (int i = 1; i <= n; ++i) {
a.push_back(i);
}
int index = 1;
while(!a.empty()){
len = a.size();
if(flag == -1){
cout<<a[(index+n-m+1)%len]<<' ';
a.erase(a.begin()+(index+n-m+1)%len);
index += (n-m);
flag = -flag;
}else{
cout<<a[(index+k-1)%len]<<' ';
a.erase(a.begin()+(index+k-1)%len);
index += k;
flag = -flag;
}
}
cout<<endl;
return 0;
}