本文主要是介绍选队长:所有人围成一圈,顺序排号。从第一个人开始报数(从 1 到 3 报数), 凡报到 3 的人退出圈子,剩下的人继续报数,最后留下的当选为队长,问最后留下的是原来第几号的那位?(数组),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
思路
- 循环只有当剩下1人时结束
- 只有当j下标的人的值不为0时,才有机会报数,否则不给报数
- 当报数到3时,下标为J的人出局,并给他赋值0
- 游戏人数减一
- 重置,从1开始报数
- 当j==n+1超过参加人数到最后一个人报数时,从头开始报数!
public static void main(String[] args) {Scanner scan = new Scanner(System.in);System.out.println("请输入参加队长竞选人数:");int n = scan.nextInt();//count记录多少人来选队长int count = n;//j用来循环人数int j = 1;//用countnum来报数;1,2,3-----1,2,3------1,2,3int countnum = 0;int[] arr = new int[n+1];//对参与竞选的人都赋值1,当有数到3的人赋值为0for(int i=1;i<=n;i++) {arr[i]=1;//System.out.print(arr[i]+" ");}//循环只有当剩下1人时结束while (count>1) {//只有当j下标的人的值不为0时,才有机会报数,否则不给报数if(arr[j]!=0) {//当报数到3时,下标为J的人出局,并给他赋值0countnum++;if(countnum==3) {//游戏人数减一count--;//j下标的人出局arr[j]=0;//重置,从1开始报数countnum=0;for(int i=1;i<=n;i++) {System.out.print(arr[i]+" ");}System.out.println(); }}//到下一个人报数j++;//当超过参加人数到最后一个人报数时,从头开始报数!if(j==n+1) {j=1;}}//输出值是1的人for (int i = 1; i < n; i++) {if(arr[i]!=0) {System.out.println("当队长的是第"+i+"个人");}}}
结果:
这篇关于选队长:所有人围成一圈,顺序排号。从第一个人开始报数(从 1 到 3 报数), 凡报到 3 的人退出圈子,剩下的人继续报数,最后留下的当选为队长,问最后留下的是原来第几号的那位?(数组)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!