欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java輸出1~100之間的全部素數(shù)的5種方式總結

 更新時間:2022年02月08日 11:00:29   作者:T-OPEN  
這篇文章主要介紹了java輸出1~100之間的全部素數(shù)的5種方式總結,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

需求:輸出1~100的所有素數(shù)

分析

1.素數(shù):

  • 判斷條件1:只能被1和本身整除的稱為素數(shù);
  • 判斷條件2:在區(qū)間(1,x/2)中找不到能整除素數(shù)x的整數(shù);
  • 判斷條件3:在區(qū)間(1,sqrt(x))中找不到能整除素數(shù)x的整數(shù);

2.方法:很多,但不外是循環(huán)嵌套外加條件語句;

class PrintSuShu {
    public static void main(String[] args) {
//方法一:根據(jù)素數(shù)的定義來遍歷檢查
//外層循環(huán)遍歷被除數(shù)i(因為1既不是素數(shù)也不是和數(shù),所以直接從2開始遍歷)
        for (int i = 2; i <= 100; i++) {
//定義一個邏輯值,初值為true
            boolean flag = true;
//內(nèi)層遍歷除數(shù)j
            for (int j = 2; j < i; j++) {
//判斷是否存在j能整除i,若存在,則更改flag的值并跳出循環(huán)
                if (0 == i % j) {
                    flag = false;
                    break;
                }
            }
//根據(jù)flag的值判斷是否輸出i
            if (flag) {
                System.out.print(i + " ");
            }
        }
        System.out.println('\n' + "---------------------------");
//方法二:根據(jù)判斷條件2進行遍歷檢查,減少遍歷次數(shù)
//外層循環(huán)遍歷被除數(shù)i(因為1既不是素數(shù)也不是和數(shù),所以直接從2開始遍歷)
        for (int i = 2; i <= 100; i++) {
//定義一個邏輯值flag,初始值為true
            boolean flag = true;
//內(nèi)層循環(huán)遍歷除數(shù)j(注意:此處若不取邊界,則當i=4時,j=2會因為小于i/2=2而直接跳出內(nèi)循環(huán))
            for (int j = 2; j <= (i / 2); j++) {
//判斷是否存在除數(shù)j能整除i,若存在,則修改flag的值并跳出循環(huán)
                if (0 == i % j) {
                    flag = false;
                    break;
                }
            }
//根據(jù)flag的值判斷是否輸出i
            if (flag) {
                System.out.print(i + " ");
            }
        }
        System.out.println('\n' + "---------------------------");
//方法三:根據(jù)判斷條件3進行遍歷檢查,減少遍歷次數(shù)
//外層循環(huán)遍歷被除數(shù)i(因為1既不是素數(shù)也不是和數(shù),所以直接從2開始遍歷)
        for (int i = 2; i <= 100; i++) {
//定義一個邏輯值flag,初始值為true
            boolean flag = true;
//內(nèi)層循環(huán)遍歷除數(shù)j(注意:此處若不取邊界,則當i=4時,j=2會因為小于sqrt(i)=2而直接跳出內(nèi)循環(huán))
//再思考一下若i=25時呢?若不取邊界還有那些不是素數(shù)的數(shù)會輸出呢?
            for (int j = 2; j <= Math.sqrt(i); j++) {
//判斷是否存在除數(shù)j能整除i,若存在,則修改flag的值并跳出循環(huán)
                if (0 == i % j) {
                    flag = false;
                    break;
                }
            }
//根據(jù)flag的值判斷是否輸出i
            if (flag) {
                System.out.print(i + " ");
            }
        }
        System.out.println('\n' + "---------------------------");
/*方法四:在方法三的前提上優(yōu)化,優(yōu)化基礎是除2外的所有偶數(shù)均不是素數(shù),
*(i+=2)只遍歷奇數(shù),減少外層遍歷次數(shù);同理,由于奇數(shù)是不能被偶數(shù)整除的,
*(j+=2)只遍歷奇數(shù),減少內(nèi)層遍歷次數(shù)
*/
        System.out.print("2 ");
//外層循環(huán)遍歷被除數(shù)i(因為1既不是素數(shù)也不是和數(shù),所以直接從2開始遍歷)
        for (int i = 3; i <= 100; i += 2) {
//定義一個邏輯值flag,初始值為true
            boolean flag = true;
//內(nèi)層循環(huán)遍歷除數(shù)j(注意:此處若不取邊界,則當i=4時,j=2會因為小于sqrt(i)=2而直接跳出內(nèi)循環(huán))
//再思考一下若i=25時呢?若不取邊界還有那些不是素數(shù)的數(shù)會輸出呢?
            for (int j = 3; j <= Math.sqrt(i); j += 2) {
//判斷是否存在除數(shù)j能整除i,若存在,則修改flag的值并跳出循環(huán)
                if (0 == i % j) {
                    flag = false;
                    break;
                }
            }
//根據(jù)flag的值判斷是否輸出i
            if (flag) {
                System.out.print(i + " ");
            }
        }
        System.out.println('\n' + "---------------------------");
//聯(lián)想一下,能被2整除(偶數(shù))的直接剔除,同樣的道理,能被3or5整除的剔除掉會不會讓外層循環(huán)的次數(shù)更少呢?
//此處才到100,若是1000呢?10000呢?
//定義一個數(shù)組,由于剔除了偶數(shù),故數(shù)組長度不會超過總個數(shù)的一半
        int[] arr = new int[500];
        int count = 0;
        for (int i = 6; i <= 1000; i++) {
            boolean flag = true;
            if (0 == i % 2 || 0 == i % 3 || 0 == i % 5) {
                flag = false;
            }
            if (flag) {
                arr[count] = i;
                count++;
            }
        }
        System.out.println("6~1000中剔除能被2or3or5整除的數(shù)后還剩" + count + "個");
        System.out.println("1~1000中所有素數(shù)為:");
        System.out.print("2" + "\t");
        System.out.print("3" + "\t");
        System.out.print("5" + "\t");
        count = 0;
        for (int i = 0; i < 500; i++) {
            boolean flag = true;
            if (0 == arr[i]) {
                break;
            }
            for (int j = 7; j <= Math.sqrt(arr[i]); j += 2) {
                if (0 == (arr[i]) % j) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                System.out.print((arr[i]) + "\t");
                count++;
            }
        }
        System.out.println("\n" + "---------------------");
        System.out.println("\n" + "其中6~1000中剔除能被2or3or5整除的數(shù)中還是素數(shù)的有" + count + "個");
    }
}

java輸出素數(shù)

java輸出1,000,000之內(nèi)的所有素數(shù)

找出素數(shù)

for(n=3;n<=1000000;) {
for(i=2;i<n;i++) {
if(n%i= =0) break;
if(i= =n-1) {
su[count]=n;
count++;
}
}
n+=2;
}

加二是因為從3開始奇數(shù)有可能是素數(shù),第一個循環(huán)遍歷1000000個數(shù),第二個循環(huán)看它是不是素數(shù)。

規(guī)范輸出

System.out.print(“2 “);
for(n=0,i=2;n<count;n++) {
System.out.printf(”%-7d”,su[n]);
if(i%10==0) System.out.println( );
i++;
}

在這里插入圖片描述

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • java實現(xiàn)讀取jar包中配置文件的幾種方式

    java實現(xiàn)讀取jar包中配置文件的幾種方式

    本文主要介紹了java實現(xiàn)讀取jar包中配置文件的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 你應該知道的java中的5個注解

    你應該知道的java中的5個注解

    自Java5.0版本引入注解之后,它就成為了Java平臺中非常重要的一部分。開發(fā)過程中,我們也時常在應用代碼中會看到像@Override,@Deprecated這樣的注解。下面小編和大家來一起學習一下吧
    2019-05-05
  • java String校招面試題過程詳解

    java String校招面試題過程詳解

    這篇文章主要介紹了java String校招面試題過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • Java中抓取 Thread Dumps 的方式匯總

    Java中抓取 Thread Dumps 的方式匯總

    Thread dumps(線程轉儲)能幫助我們判斷 CPU 峰值、死鎖、內(nèi)存異常、應用反應遲鈍、響應時間變長和其他系統(tǒng)問題。在這篇文章當中,總結了7中抓取 Java Thread Dumps 文件的方式,分享給大家,希望對大家學習Java能夠有所幫助。
    2016-06-06
  • Lombok 的@StandardException注解解析

    Lombok 的@StandardException注解解析

    @StandardException 是一個實驗性的注解,添加到 Project Lombok 的 v__1.18.22 版本中,在本教程中,我們將使用 Lombok 的 @StandardException 注解自動生成異常類型類的構造函數(shù),需要的朋友可以參考下
    2023-05-05
  • JAVA 區(qū)分集合和數(shù)組

    JAVA 區(qū)分集合和數(shù)組

    這篇文章主要介紹了JAVA如何區(qū)分集合和數(shù)組,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-06-06
  • Java實現(xiàn)指定目錄下的文件查找詳解

    Java實現(xiàn)指定目錄下的文件查找詳解

    這篇文章主要介紹了利用Java實現(xiàn)指定目錄下的文件查找的方法,能做到給出文件名,查找目錄及其子目錄中是否存在或者給出后綴名,查找目錄及其子目錄中相關的文件,感興趣的可以學習一下
    2022-03-03
  • Spring Boot Web應用開發(fā) CORS 跨域請求支持

    Spring Boot Web應用開發(fā) CORS 跨域請求支持

    本篇文章主要介紹了Spring Boot Web應用開發(fā) CORS 跨域請求支持,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • Mybatis的dao層,service層的封裝方式

    Mybatis的dao層,service層的封裝方式

    這篇文章主要介紹了Mybatis的dao層,service層的封裝方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • SpringBoot如何在線程中獲取@Service Bean類

    SpringBoot如何在線程中獲取@Service Bean類

    這篇文章主要介紹了SpringBoot如何在線程中獲取@Service Bean類,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02

最新評論