Java打印素数(质数)

要求:打印 2 - 100000 当中的素数与非素数。(素数定义:在大于1的自然数中,除了1和它本身以外不再有其他因数)

1. 常规方式——对正整数n,如果用2到  之间的所有整数去除,均无法整除,则n为质数:

  // sqrt 法
  public static void printPrime1(int num) {
    boolean[] isPrimes = new boolean[num + 1];
    for (int i = 2; i < isPrimes.length; i++) {
      isPrimes[i] = true;
    }

    for (int i = 3; i <= num; i++) {
      for (int j = 2; j <= Math.sqrt(i); j++) {
        if (i % j == 0) {
          isPrimes[i] = false;
          break;
        }
      }
    }

    System.out.print("质数有: ");
    for (int i = 2; i < isPrimes.length; i++) {
      if (isPrimes[i]) {
        System.out.print(i + " ");
      }
    }
    System.out.println("");
    System.out.print("非质数有: ");
    for (int i = 2; i < isPrimes.length; i++) {
      if (!isPrimes[i]) {
        System.out.print(i + " ");
      }
    }
  }

  注意这里用一个布尔类型的数组用于素数的判断与最终结果的打印,避免了使用两个容器去分别存放各自需要打印的两块内容。

 2. 埃氏筛选法

  // 埃氏筛法
  public static void printPrime2(int num) {
    boolean[] isPrimes = new boolean[num + 1];
    for (int i = 2; i < isPrimes.length; i++) {
      isPrimes[i] = true;
    }
    for (int i = 2; i < num; i++) {
      if (isPrimes[i] == true) {
        for (int j = 2; i * j <= num; j++) {
          isPrimes[i * j] = false;
        }
      }
    }

    System.out.print("质数有: ");
    for (int i = 2; i < isPrimes.length; i++) {
      if (isPrimes[i]) {
        System.out.print(i + " ");
      }
    }
    System.out.println("");
    System.out.print("非质数有: ");
    for (int i = 2; i < isPrimes.length; i++) {
      if (!isPrimes[i]) {
        System.out.print(i + " ");
      }
    }
  }

  最后提供一个main方法,完成对两个方法的调用与性能比较:

  public static void main(String[] args) {
    long timePoint1 = System.currentTimeMillis();
    printPrime1(100000);
    long timePoint2 = System.currentTimeMillis();
    System.out.println();
    printPrime2(100000);
    long timePoint3 = System.currentTimeMillis();

    System.out.println();
    System.out.println("sqrt法耗时: " + String.valueOf(timePoint2 - timePoint1)); // 390 ms
    System.out.println("埃氏筛法耗时: " + String.valueOf(timePoint3 - timePoint2)); // 297 ms
  }

原文地址:https://www.cnblogs.com/binye-typing/p/9261118.html

时间: 2024-10-07 03:12:41

Java打印素数(质数)的相关文章

java 打印素数

public class 打印素数 { public static void main(String args[]) { System.out.println("3--100之间的素数有:"); boolean isprime; int iCount=0; for(int i=3;i<=100;i++) { isprime=true; for(int j=2;j<=i/2;j++) { if(i%j==0) { isprime=false; break; } } if(is

Java打印整数的二进制表示(代码与解析)

Java打印整数的二进制表示(代码与解析) int a=-99; for(int i=0;i<32;i++){ int t=(a & 0x80000000>>>i)>>>(31-i); System.out.print(t); } 拆分一下这段代码,要理解这个移位输出的问题还需要理解的以下内容:* 0x80000000是数的十六进制表示,转成二进制表示为10000000000000000000000000000000* 运算的优先级,移位运算高于逻辑运算,

java 打印流PrintWriter基本操作

import java.io.*; public class PrintDemo { public static void main(String[] args) { PrintWriter writer=null; writer=new PrintWriter(System.out); String str=new String("Hello cjc!!!"); writer.print(str); writer.close(); try { writer=new PrintWrit

代码实现:判断101-200之间有多少个素数(质数),并输出所有素数。 程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。

package com.heima.Coding; /* 判断101-200之间有多少个素数(质数),并输出所有素数. 程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数.*/ public class Test { public static void main(String[] args) { int count = 0; for (int i = 100; i < 200; i++) { for (int j = 2; j <=

java打印正金字塔,倒金字塔和“水影”金字塔

java打印正金字塔,倒金字塔和"水影"金字塔 --------原创文章,若要转载,请注明出处 小小少年 闲来无事,想起自己初学java的时候做的经典的无非就是打印出一些有意思的图形,心血来潮自己就写了这么一个打印金字塔的demo,自己回顾一下当初的感受,同时也 分享给初学java的同道中人,一起来培养编程的兴趣<(^-^)>. 金字塔图案 1,问题分析 我们都知道,打印输出的时候,都是从最左端输出,而这里,第一个星号是在中间.这实际是因为星号之前有很多空格.当我们使用问号

Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录)

Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录) 作者:王可利(Star·星星) 效果图: 代码如下: 1 class Star8 2 { 3 public static void main(String[] args) 4 { 5 /* 空格 6 * 1 2*i-1 3 4-1 4-i 7 *** 3 2 4-2 8 ***** 5 1 4-3 9 ******* 7 0 4-4 10 */ 11 //第一层循环控制的是行数 12 for(int i = 1;i<=

关于这两天研究Java打印pdf方法的记录

这两天在研究Java调用打印机打印PDF文件的方法,学到了不少东西,特别来记录一下. 关于Java打印网上最多的而且也是Java正统的打印方法就是使用PrintService,一套比較标准的打印代码例如以下: public class PrintDemo { public static void main(String[] args) { JFileChooser fileChooser = new JFileChooser(); // 创建打印作业 int state = fileChoose

Java求素数

Java求素数 package test1; import java.util.*; public class Demo { public static void main(String[] args) { Scanner scan = new Scanner(System.in); int a = scan.nextInt(); if(a==2){ System.out.println("2"); System.exit(0); } for(int b=3;b<a;b++) {

用Java打印乘法口诀表

用Java打印乘法口诀表: public class MultiplicationTable{ public static void main(String[] args){ for(int i = 1; i < 10; i++){ for(int j = 1; j <= i; j++){ System.out.print(j + "*" + i + "=" + i*j + " "); } System.out.print("