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

Java求質(zhì)數(shù)的幾種常用算法分析

 更新時(shí)間:2018年12月29日 10:38:58   作者:Wonder  
這篇文章主要介紹了Java求質(zhì)數(shù)的幾種常用算法,結(jié)合實(shí)例形式分析了三種比較常見(jiàn)的求質(zhì)數(shù)算法原理及相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了Java求質(zhì)數(shù)的幾種常用算法。分享給大家供大家參考,具體如下:

1、根據(jù)質(zhì)數(shù)的定義求

質(zhì)數(shù)定義:只能被1或者自身整除的自然數(shù)(不包括1),稱(chēng)為質(zhì)數(shù)。

利用它的定義可以循環(huán)判斷該數(shù)除以比它小的每個(gè)自然數(shù)(大于1),如果有能被它整除的,則它就不是質(zhì)數(shù)。

對(duì)應(yīng)代碼是:

void printPrime(int n){//判斷n是否是質(zhì)數(shù)
  boolean isPrime=true;//是否是質(zhì)數(shù)的標(biāo)志
  for(int i=n-1;i>1;i—){//n除以每個(gè)比n小比1大的自然數(shù)
   if(n%i==0){//如果有能被整除的,則不是質(zhì)數(shù)
    isPrime=false;
   }
  }
  if(isPrime){//如果是質(zhì)數(shù),則打印出來(lái)
   System.out.print(n+" ");
   primeNumber++;//記錄質(zhì)數(shù)的個(gè)數(shù)
   if(primeNumber%10==0)//輸出10個(gè)質(zhì)數(shù)后換行
    System.out.println();
  }
}

2、利用一個(gè)定理——如果一個(gè)數(shù)是合數(shù),那么它的最小質(zhì)因數(shù)肯定小于等于他的平方根。例如:50,最小質(zhì)因數(shù)是2,2<50的開(kāi)根號(hào)

再比如:15,最小質(zhì)因數(shù)是3,3<15的開(kāi)根號(hào)

合數(shù)是與質(zhì)數(shù)相對(duì)應(yīng)的自然數(shù)。一個(gè)大于1的自然數(shù)如果它不是合數(shù),則它是質(zhì)數(shù)。
上面的定理是說(shuō),如果一個(gè)數(shù)能被它的最小質(zhì)因數(shù)整除的話(huà),那它肯定是合數(shù),即不是質(zhì)數(shù)。所以判斷一個(gè)數(shù)是否是質(zhì)數(shù),只需判斷它是否能被小于它開(kāi)跟后后的所有數(shù)整除,這樣做的運(yùn)算就會(huì)少了很多,因此效率也高了很多。

對(duì)應(yīng)代碼是:

void printPrime(int n){//判斷n是否是質(zhì)數(shù)
  boolean isPrime=true;//是否是質(zhì)數(shù)的標(biāo)志
  int s=(int)Math.sqrt(n);//對(duì)n開(kāi)根號(hào)
  for(int i=s;i>1;i—){//n除以每個(gè)比n開(kāi)根號(hào)小比1大的自然數(shù)
   if(n%i==0){//如果有能被整除的,則不是質(zhì)數(shù)
    isPrime=false;
   }
  }
  if(isPrime){//如果是質(zhì)數(shù),則打印出來(lái)
   System.out.print(n+" ");
   primeNumber++;//記錄質(zhì)數(shù)的個(gè)數(shù)
   if(primeNumber%10==0)//輸出10個(gè)質(zhì)數(shù)后換行
    System.out.println();
  }
}

3、篩法求質(zhì)數(shù),效率最高,但會(huì)比較浪費(fèi)內(nèi)存

首先建立一個(gè)boolean類(lèi)型的數(shù)組,用來(lái)存儲(chǔ)你要判斷某個(gè)范圍內(nèi)自然數(shù)中的質(zhì)數(shù),例如,你要輸出小于200的質(zhì)數(shù),你需要建立一個(gè)大小為201(建立201個(gè)存儲(chǔ)位置是為了讓數(shù)組位置與其大小相同)的boolean數(shù)組,初始化為true。

其次用第二種方法求的第一個(gè)質(zhì)數(shù)(在此是2),然后將是2的倍數(shù)的數(shù)全置為false(2除外),即2、4、6、8……位置上置為false。然后是3的倍數(shù)的全置為false(3除外),一直到14(14是200的開(kāi)平方),這樣的話(huà)把不是質(zhì)數(shù)的位置上置為false了,剩下的全是質(zhì)數(shù)了,挑著是true的打印出來(lái)就行了。

對(duì)應(yīng)代碼是:

boolean[] printPrime(int range){
  boolean[] isPrime=new boolean[range+1];
  isPrime[1]=false;//1不是質(zhì)數(shù)
  Arrays.fill(isPrime, 2,range+1,true);//全置為true(大于等于2的位置上)
  int n=(int)Math.sqrt(range);//對(duì)range開(kāi)根號(hào)
  for(int i=2;i<=n;i++)//注意需要小于等于n
   if(isPrime[i])//查看是不是已經(jīng)置false過(guò)了
    for(int j=i;j*i<range;j++)//將是i倍數(shù)的位置置為false
     isPrime[j*i]=false;
  return isPrime;//返回一個(gè)boolean數(shù)組
}

PS:這里再為大家推薦一款功能相似的在線(xiàn)工具供大家參考:

在線(xiàn)分解質(zhì)因數(shù)計(jì)算器工具:
http://tools.jb51.net/jisuanqi/factor_calc

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總

希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • GraalVM系列Native?Image?Basics靜態(tài)分析

    GraalVM系列Native?Image?Basics靜態(tài)分析

    這篇文章主要為大家介紹了GraalVM系列Native?Image?Basics靜態(tài)分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Java面試基礎(chǔ)之TCP連接以及其優(yōu)化

    Java面試基礎(chǔ)之TCP連接以及其優(yōu)化

    這篇文章主要給大家介紹了關(guān)于Java面試基礎(chǔ)之TCP連接以及其優(yōu)化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Java原生序列化和反序列化代碼實(shí)例

    Java原生序列化和反序列化代碼實(shí)例

    這篇文章主要介紹了Java原生序列化和反序列化代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • C++ 程序流程結(jié)構(gòu)詳解

    C++ 程序流程結(jié)構(gòu)詳解

    這篇文章主要介紹了C++程序的程序流程結(jié)構(gòu)以及關(guān)系和邏輯運(yùn)算符講解,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2021-09-09
  • SpringBoot接收LocalDateTime參數(shù)的方式

    SpringBoot接收LocalDateTime參數(shù)的方式

    這篇文章主要介紹了SpringBoot接收LocalDateTime參數(shù)的方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • Springboot自定義全局異常問(wèn)題

    Springboot自定義全局異常問(wèn)題

    這篇文章主要介紹了Springboot自定義全局異常問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • IDEA2020 1.1中Plugins加載不出來(lái)的問(wèn)題及解決方法

    IDEA2020 1.1中Plugins加載不出來(lái)的問(wèn)題及解決方法

    這篇文章主要介紹了IDEA2020 1.1中Plugins加載不出來(lái)的問(wèn)題,本文還給大家提到了IDEA 2020.1.1 找不到程序包和符號(hào)的問(wèn)題,感興趣的朋友跟隨小編一起看看吧
    2020-06-06
  • mybatis-plus阻止全表更新與刪除的實(shí)現(xiàn)

    mybatis-plus阻止全表更新與刪除的實(shí)現(xiàn)

    BlockAttackInnerInterceptor 是mybatis-plus的一個(gè)內(nèi)置攔截器,用于防止惡意的全表更新或刪除操作,本文主要介紹了mybatis-plus阻止全表更新與刪除的實(shí)現(xiàn),感興趣的可以了解一下
    2023-12-12
  • 利用java批量給pdf加水印的方法示例

    利用java批量給pdf加水印的方法示例

    這篇文章主要介紹了利用java批量給pdf加水印的方法,文中給出了簡(jiǎn)單的示例代碼,需要的朋友可以參考借鑒,下面來(lái)一起看吧。
    2017-03-03
  • Springboot項(xiàng)目保存本地系統(tǒng)日志文件的實(shí)現(xiàn)方法

    Springboot項(xiàng)目保存本地系統(tǒng)日志文件的實(shí)現(xiàn)方法

    這篇文章主要介紹了Springboot項(xiàng)目保存本地系統(tǒng)日志文件的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04

最新評(píng)論