 宁静 2022-08-24 07:29 采纳率: 100%
浏览 34
已结题

https://noi.vip/problem/1034选警长

题目链接:https://noi.vip/problem/1034
警队有N个人排成一队,从第1个人开始依次顺序报号一遍,凡报号为M和M的倍数者退出队伍。
如果一次报号中没有报号为M和M倍数者,则从第一个人接续报号,保证每次从队伍中退出一人。 然后再重新从第一个人开始依次报号一遍,重复上述过程,直到队伍中剩余最后一人。

找出最后一个留在队伍的警长的序号
输入样例:

5 3

输出样例:

2

求C++代码

  • 写回答

2条回答 默认 最新

  • CSDN专家-link 2022-08-24 08:39
    关注

    意思是如果一次报号中有M或M的倍数,下一遍就不是第一个人接续报号了?

    #include <iostream>
    using namespace std;
    #include <string.h>
    
    int main()
    {
        int M,N,i;
        cin>>N>>M;
        int *out = new int[N];
        memset(out,0,N*sizeof(int));
        int count = 0,num = 0;
        do
        {
            count = 0;
            for(i=0;i<N;i++)
            {
                if(!out[i])
                {
                    count++;
                    if(count % M == 0)
                        out[i] = 1;
                }
            }
        }while(count >= M);
        //
        do
        {
            count = 0;
            for(i=0;i<M-1;i++)
            {
                if(!out[i])
                {
                    count++;
                    num++;
                    if(num%M==0)
                    {
                        out[i] = 1;
                        num = 0;
                    }
                }
            }
        }while(count > 1);
        //
        for(i=0;i<N;i++)
            if(!out[i])
            {
                cout<<i+1;
                break;
            }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月1日
  • 已采纳回答 8月24日
  • 修改了问题 8月24日
  • 修改了问题 8月24日
  • 展开全部

悬赏问题

  • ¥100 关于#VijeoCitect#的问题,如何解决?(标签-ar|关键词-数据类型)
  • ¥30 数字信号处理实验报告
  • ¥15 一个矿井排水监控系统的plc梯形图,求各程序段都是什么意思
  • ¥15 ensp路由器启动不了一直报#
  • ¥50 安卓10如何在没有root权限的情况下设置开机自动启动指定app?
  • ¥15 ats2837 spi2从机的代码
  • ¥200 wsl2 vllm qwen1.5部署问题
  • ¥100 有偿求数字经济对经贸的影响机制的一个数学模型,弄不出来已经快要碎掉了
  • ¥15 数学建模数学建模需要
  • ¥15 已知许多点位,想通过高斯分布来随机选择固定数量的点位怎么改