假设班上有25个人,按照一定的规则选举班长,规则如下:将班里的N个人围城一圈,顺序编号,从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,然后从下一个人重新开始,最后留下的那个人就被选为班长,请问按照这个规则,选出的班长是原来编号为第几号的学生?
public class six {
public static void main(String[] args) {
int[] num = new int[25];
int count = 0;
int x = 25 ;//用来记录数组中不为0的数的个数
for (int i = 0 ; i < 25 ; i++){
num[i] = i + 1 ;
}
while (x > 1){
for (int i = 0 ; i < 25 ; i++){
if (num[i] != 0){
count++;
if (count == 3){
num[i] = 0 ;
x--;
count = 0 ;
}
}
}
}
for (int i = 0 ; i < 25 ; i++){
if (num[i] != 0){
System.out.println("选出的班长是原来编号为第" + num[i] + "号的学生");
}
}
}
}