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

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

import java.util.ArrayList;

import java.util.List;

import java.util.Scanner;

public class Circle{

public static void main(String[] args) {

    System.out.println("请输入围成圈的人数:");

    @SuppressWarnings("resource")

    Scanner input=new Scanner(System.in);

    int n=input.nextInt();

    List<Integer> group=newArrayList<Integer>();

    //1、给数组列表初始化数据

    for(int i=1;i<=n;i++){

       group.add(i);

    }

    //2、报数

    int number=1;//第一个人报数为1

          //圈里的人循环报数

       for(int i=0;i<n;i++){   

           if(number==3){//当圈里第i+1个人报道的数是3

              group.remove(i);//圈里第i+1个人退出圈子

              i--;//下一个报数的人在数组列表中的下标值

              n--;//圈子的总人数减少1   

              number=0;//通过number++,下一个人报的数是1

           }

           number++;  //报数时,每次加

           if(i==n-1){//当所有的人报完一圈

              i=-1;//下一次从圈里的第一个人报,通过for循环的i++,对应数组列表下标值为0

           }

           if(n==1){//如果整个圈子最后只剩下一人

              break;

           }

      

    }

    System.out.println("最后留下的是原来"+group.get(0)+"号的那位。");

}

}

  • 9
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值