 宁静 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日
  • 展开全部

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?