当前位置:首页 > 题解目录 > 正文内容

【题解】幸运儿

亿万年的星光11个月前 (04-04)题解目录731

【题目描述】

n 个人围成一圈, 并依次编号1~n,从编号为1 的人开始,按顺时针方向每隔一人选出一个,当一圈结束之后,剩下的人重新围成一圈,再次从编号1的人开始,如此循环直到剩下两人,这剩下的两人就是幸运儿。如果你想成为最后两个幸运儿,请问开始时应该站在什么位置?(设3<=n<=50)

【输入描述】

有多个测试序列。每行是开始时的人数n

【输出描述】

第1 行是选出顺序,第2 行是两名幸运儿的开始位置(按升序排列),位置编号之间用一个空格分开。

【样例输入】

12
20

【样例输出】

2 4 6 8 10 12 3 7 11 5
1 9
2 4 6 8 10 12 14 16 18 20 3 7 11 15 19 5 13 9
1 17


【参考答案】

#include<iostream>
#include<queue>
using namespace std;
int main(){
    int n;
    while(cin>>n){
        queue<int> q;
        for(int i=1;i<=n;i++){
            q.push(i);
        }
        int k=1;
        while(!q.empty()){
            if(q.size()==2){
                break;
            }
            if(q.front()==1){
                k=1;
            }
            if(k==2){
                cout<<q.front()<<" ";
                q.pop();
                k=1;
            }else{
                q.push(q.front());
                q.pop();
                k++;
            }
        }
        cout<<endl;
        int k1[2];
        int i=0;
        while(!q.empty()){
            k1[i++]=q.front();
            q.pop();
        }
        if(k1[0]>k1[1]){
            cout<<k1[1]<<" "<<k1[0]<<endl;
        }else{
            cout<<k1[0]<<" "<<k1[1]<<endl;
        }
    }
    return 0;
}


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    【题解】给定和为定数

    【题目描述】给出若干个整数,询问其中是否有一对数的和等于给定的数。【输入描述】第一行是整数n(0 < n ≤ 100,000),表示有n个整数。第二行是n个整数。整数的范围是在0到108之间。第...

    【题解】线段

    【题目描述】在一个数轴上有n条线段,现选取其中k条线段使得这k条线段两两没有重合部分,问最大的k为多少?【输入描述】第一行为一个正整数n,下面n行每行2个数字ai,bi,描述每条线段。【输出描述】输出...

    【题解】校运会

    【题解】校运会

    【题目描述】校运会上,一共有N个参赛选手,已知N个选手的名字。然后老师告诉你M句话,话的内容是学生A与学生B在同一组里。如果学生A与学生B在同一组里,学生B与学生C也在同一组里,就说明学生A与学生C在...

    【题解】运动员和训练师的最大匹配数

    【题目描述】给你一个下标从 0 开始的整数数组 players ,其中 players[i] 表示第 i 名运动员的&n...

    【题解】最小子序列

    【题目描述】给你一个数组 nums,请你从中抽取一个子序列,满足该子序列的元素之和 严格 大于未包含在该子序列中的各元素之和。如果存在多个解决方案,只需返回 长...

    【题解】分糖果

    【题目描述】小A在生日这天收到了哥哥送来的一盒糖果,这盒糖果共有M个,小A要把这盒糖果放到N个盘子中(允许有盘子不放),请问,有多少种不同的放法?请注意:数值相同,顺序不同,我们视为是相同的放法,比如...