解题思路: 严格按照题目要求,用数组模拟m个人,逐一报数,遇到已报过3的人就跳过,报到3后再从1重头报数,直到只剩最后一人。

注意事项: i%=m,以保证报数的人不超过m范围,count%=3,以保证报的数不超过3

参考代码:

#include<iostream>

using namespace std;


int main()

{

    int n;

    cin>>n;        //输入参加游戏的人数

    int child[n]={0};

    int i=0,count=0,remain=n;    //i是参加游戏的人的序号,count记每个人应该报的数,remain记参与游戏还剩余的人数

    while(remain>1){            //如果剩余游戏人数多于1,则继续

        if(child[i]!=3){            //已经报过3的人跳过,保证参与报数的人是没有报过3的

            count++;                //本轮应报的数,(在一上数基础上+1)

            child[i]=count;        //参与的人报数

            count%=3;            // 报到3则归0

            if(count==0) remain--;        //遇到报3的人,剩余人数减1

        }

        i++;                            //序号加1,到下一个人

        i=i%n;                        //保证序号不超人数

    }

    for(int j=0;j<n;j++){

        if(child[j]!=3) cout<<j+1;        //数组序号从0开始,游戏人序号从1开始,所以要加1

    }

    

    return 0;

}


点赞(1)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论