报数游戏

这是一个编程问题,描述了一种报数游戏的场景:n个人围成一圈按顺序报数,每报到3的人退出。文章介绍了通过使用布尔数组记录存活状态来找出最后留下的参与者原本的编号。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

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

思路

第一思路是链表,后来细思觉得没有必要这么麻烦,其实可以通过一个布尔数组来标志人的存活状态,只要只剩一个人了就是最后存活的人,其数组索引+1便是他的标号。

代码

public static int theLastSurvivor(int peopleNum){
        int index=0;//当前索引
        int currentCount=1;//当前人报的数
        boolean [] islives = new boolean[peopleNum];//false代表已出局,true代表存活
        int livingNum = islives.length;
        for(int i=0;i<peopleNum;i++){
            islives[i]=true;//初始化
        }
        while(livingNum>1){
            if(islives[index]){
                if(currentCount==3){
                    islives[index]=false;
                    livingNum--;
                    currentCount=1;
                }else {
                    currentCount++;
                }
            }
            index++;
            if(index==peopleNum){
                index=0;//若到结尾,从头遍历
            }
        }
        for(int i=0;i<islives.length;i++){
            if(islives[i])
                return i+1;
        }
        return 0;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值