原题链接:[编程入门]筛选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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复