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

关于#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日
  • 展开全部

悬赏问题

  • ¥15 preLaunchTask"C/C++: aarch64- apple-darwin22-g++-14 生成活动 文件”已终止,退出代码为-1。
  • ¥60 如何鉴定微信小程序数据被篡改过
  • ¥18 关于#贝叶斯概率#的问题:这篇文章中利用em算法求出了对数似然值作为概率表参数,然后进行概率表计算,这个概率表是怎样计算的呀
  • ¥20 C#上传XML格式数据
  • ¥15 elementui上传结合oss接口断点续传,现在只差停止上传和继续上传,各大精英看下
  • ¥100 单片机hardfaulr
  • ¥20 手机截图相片分辨率降低一半
  • ¥50 求一段sql语句,遇到小难题了,可以50米解决
  • ¥15 速求,对多种商品的购买力优化问题(用遗传算法、枚举法、粒子群算法、模拟退火算法等方法求解)
  • ¥100 速求!商品购买力最优化问题(用遗传算法求解,给出python代码)