Ne pars pas. 2021-10-22 15:30 采纳率: 50%
浏览 28
已结题

c++实现不断删除奇数位置到只剩最后一个

有思路写不出编程。。
原题是一百个和尚
皇帝要杀掉奇数位
一轮下来后再删掉新的奇数位
只剩下一个是幸存者

  • 写回答

3条回答 默认 最新

  • CSDN专家-link 2021-10-22 15:54
    关注

    定义 int a[100]={0},然后根据下标扫描,奇数顺序的下标就把值设置为1,直到一遍扫描只有1个不为0的结束

    #include <stdio.h>
    void main()
    {
        int a[101] = {0};
        int count =0;
        while(1)
        {
            count = 0;
            for(int i=1;i<=100;i++)
            {
                if(a[i] == 0)
                    count++;
                if(count%2==1)
                    a[i] = 1;
            }
            if(count <= 3)
                break;
        }
        for(int i=1;i<=100;i++)
        {
            if(a[i] == 0)
                printf("%d\n",i);
        }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月30日
  • 已采纳回答 10月22日
  • 创建了问题 10月22日

悬赏问题

  • ¥15 WPF动态创建页面内容
  • ¥15 如何对TBSS的结果进行统计学的分析已完成置换检验,如何在最终的TBSS输出结果提取除具体值及如何做进一步相关性分析
  • ¥15 SQL数据库操作问题
  • ¥100 关于lm339比较电路出现的问题
  • ¥15 Matlab安装yalmip和cplex功能安装失败
  • ¥15 加装宝马安卓中控改变开机画面
  • ¥15 STK安装问题问问大家,这种情况应该怎么办
  • ¥15 关于罗技鼠标宏lua文件的问题
  • ¥15 halcon ocr mlp 识别问题
  • ¥15 已知曲线满足正余弦函数,根据其峰值,还原出整条曲线