原题链接:[编程入门]筛选N以内的素数
import java.io.*;
/**
* 筛法求素数
*/
public class Main {
public static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
public static BufferedWriter out = new BufferedWriter(new OutputStreamWriter(System.out));
public static StreamTokenizer cin = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
public static PrintWriter cout = new PrintWriter(new OutputStreamWriter(System.out));
static boolean[] judgeNumber(int n) {
boolean[] f = new boolean[n + 1];
f[1] = false;
for (int i = 2; i < n; i++) { // 把从 2 开始的数全部初始化
f[i] = true;
}
f[0] = false; // 0 无意义,置为 false
for (int i = 2; i <= n; i++) { // 质数的倍数(1 倍数除外)必然是合数
if (f[i] == true) {
for (int j = 2; j * i <= n; j++) {
f[i * j] = false;
}
}
}
return f;
}
public static void main(String[] args) throws Exception {
cin.nextToken();
int n = (int) cin.nval;
boolean[] b = judgeNumber(n);
for (int i = 0; i < b.length; i++) {
if (b[i] == true) {
cout.println(i);
}
}
cout.flush();
}
} 0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复