C语言实例-约瑟夫生者死者小游戏

问题:

30个人在一条船上,超载,需要15人下船。于是人们排成一队,排队的位置即为他们的编号。报数,从1开始,数到9的人下船,如此循环,直到船上仅剩15人为止,问都有哪些编号的人下船了呢?

代码:
#include <stdio.h>

int main(){

    int count = 0; //下船人数
    int baoshu = 0;//报数
    int i=0;//编号
    int b[31] = {0};

    //当下船人数小于15时,一直循环
    while(count<15){
        
        //从1到30循环
        i++;
        if(i >= 31) i=1;
        
        //报数时跳过已经标记为下船的人
        if(b[i] == 0){baoshu++;}

        if(baoshu == 9) 
        {
            b[i] = 1; //标记为下船
            count++;//下船人数
            printf("i=%d \tb[%d]=%d\t 第%d个下船\t 编号:%d\n",i,i,b[i],count,i);

            //重置报数 
            //报数归1,同时i值增加至下一个b[i]!=1的位置
            //do-while循环是解决连续多个b[i]=1的情况
            do{
                i++;
                if(i >= 31) i=1;
            } while (b[i]!=0);
            baoshu = 1;
        }
    }

    return 0;
}
运行结果:

相关推荐

  1. C#实现环算法

    2024-07-22 01:08:03       42 阅读
  2. C语言每日一题—问题

    2024-07-22 01:08:03       22 阅读
  3. C 练习实例69-

    2024-07-22 01:08:03       55 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-22 01:08:03       57 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-22 01:08:03       60 阅读
  3. 在Django里面运行非项目文件

    2024-07-22 01:08:03       48 阅读
  4. Python语言-面向对象

    2024-07-22 01:08:03       60 阅读

热门阅读

  1. 嵌入式软件技术能力

    2024-07-22 01:08:03       16 阅读
  2. Mad MAD Sum-Codeforces Round 960 (Div. 2)

    2024-07-22 01:08:03       22 阅读
  3. js | Core

    js | Core

    2024-07-22 01:08:03      16 阅读
  4. 堆、栈和队列(数据结构)

    2024-07-22 01:08:03       22 阅读
  5. 关于Spring Boot IOC&DC,看这一篇就够了

    2024-07-22 01:08:03       18 阅读
  6. 关于数据库索引

    2024-07-22 01:08:03       21 阅读
  7. 【Node.js基础04】node.js模块化

    2024-07-22 01:08:03       19 阅读
  8. Postman实战案例:从零开始设计API测试流程

    2024-07-22 01:08:03       21 阅读
  9. linux文本查看命令

    2024-07-22 01:08:03       17 阅读
  10. 基于深度学习的医学影像分类

    2024-07-22 01:08:03       20 阅读
  11. 装修前需要提前准备啥

    2024-07-22 01:08:03       19 阅读