解题思路:
报数,报到3就排除,所以创建一个n的boolean类型数组,计入count,如果count%3==0,那么就是报到3的那个人
注意事项:
好简单好简单,我不想说啦!!!可能要注意的一个地方就是,当for循环中 ,可能会在一次对整个数组的循环删去的数大于n-1,所以要加一个条件,条件达成了自动退出循环
参考代码:

import java.util.*;


public class Main{

// static BufferedReader bf=new BufferedReader(new InputStreamReader(System.in));

// static PrintWriter pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out)));

public static void main(String[] args) {

Scanner sc=new Scanner(System.in);

int n=sc.nextInt();

//判段是否被排除,初始化为全部没有被排除

boolean[] arr=new boolean[n+1];

int count=0;

int num=0;

while(count!=n-1) {

for(int i=1;i<=n&&count!=n-1;i++) {

if(!arr[i]) {

num++;

if(num%3==0) {

arr[i]=true;

count++;

}

}

}

}


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

if(!arr[i]) {

System.out.println(i);

}

}

}

}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

等我吃个橙子 2年前 回复TA
我这个小白还在用循环链表。。。