makabaka qaq 2022-04-21 19:16 采纳率: 92.9%
浏览 48
已结题

关于#c++#的问题:约瑟夫环问题

设编号为1,2,…,n(n>0)个人按顺时针方向围坐一圈,每人持有一个正整数密码。开始时任意给出一个报数上限值m,从第一个人开始顺时针方向自1起顺序报数,报到m时停止报数,报m的人出列,将他的密码作为新的m值,从他顺时针方向上的下一个人起重新自1起顺序报数,报m的人出列,并将他的密码作为新的m值;如此下去,直到所有人全部出列为止。

设计一个程序模拟此过程,并给出出列人的编号序列。

#该怎么把每个人的顺序放到新数组里呢?

  • 写回答

2条回答 默认 最新

  • CSDN专家-link 2022-04-22 08:26
    关注

    不需要建立新数组,出局的人只需要设定一个标志量就可以了。再定义一个变量记录当前还有多少人没出局。

    struct man
    {
        int m;
        bool k;
    };
    int main()
    {
        srand(time(NULL));
        struct man s[100];
        int n,i,m,now;
        cin>>n>>m;
        now = n;
        for(i=0;i<n;i++)
        {
            s[i].m = rand()%5+1;
            s[i].k = true;
        }
        i=0;
        while(now > 0)
        {
            int count = 0;
            while(1)
            {
                if(s[i].k)
                {
                    count++;
                    if(count == m)
                    {
                        s[i].k = false;
                        m = s[i].m;
                        cout<<i+1<<" "<<m<<endl;
                        now--;
                        i++;
                        if(i>=n)
                            i=0;
                        break;
                    }
                }
                i++;
                if(i>=n)
                    i=0;
            }
        }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月8日
  • 已采纳回答 4月30日
  • 修改了问题 4月22日
  • 修改了问题 4月21日
  • 展开全部

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效