C语言经典例69-有n个人围成一圈报数问题

1 题目

有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

2 分析

假设全部人都退圈,则最后一个退圈的人就是题目中留下的那一位,详细思路请见实现中的注释。

3 实现

#include <stdio.h>

int main()
{
    int a[100]; // 保存人数的数组
    int n; // 用户输入初始有多少人
    int i; // 循环控制变量
    int k = 0; // 统计一共有多少人退圈,初始为0
    int count = 0; // 每轮报号累加数
    int lastone; // 记录每轮退圈的人的号码
    printf("请输入人数:");
    scanf("%d", &n); //n为人数
    //对于每个人a[i], 他的编号实际上是i+1
    for (i = 0; i < n; i++) {
        // i表示人的状态,若a[i]=1,则表示i+1号在圈内
        // 若a[i]=0,则表示i+1号在圈外,初始所有人都在圈内
        a[i] = 1;
    }
    // 当所有人都退出圈子时停止循环
    // 最后退圈的人就是题中有一个留在圈内的那个人
    while (k < n) {
        //对所有编号开始循环
        for (i = 0; i < n; i++) {
            //判断i+1号是否在圈内
            if (a[i] == 1) {
                //若在圈内,则报号
                count++; 
                //判断号码是否为3的倍数
                if (count % 3 == 0) {
                    a[i] = 0; //若是3的倍数,则a[i]出圈
                    k++; //退圈人数+1
                    lastone = i + 1; //记录此时退圈人的号码
                }
            }
        }
    }
    //将最后退圈的人的号码输出
    printf("留下来的那个是%d号\n", lastone);
}

4 运行结果

PS E:\C++WorkSpace> cd "e:\C++WorkSpace\" ; if ($?) { g++ FFF.cpp -o FFF } ; if ($?) { .\FFF }
请输入人数:8
留下来的那个是7号
PS E:\C++WorkSpace> cd "e:\C++WorkSpace\" ; if ($?) { g++ FFF.cpp -o FFF } ; if ($?) { .\FFF }
请输入人数:20
留下来的那个是20号
PS E:\C++WorkSpace> cd "e:\C++WorkSpace\" ; if ($?) { g++ FFF.cpp -o FFF } ; if ($?) { .\FFF }
请输入人数:17
留下来的那个是11
  • 118
    点赞
  • 381
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值