麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > Java > 正文

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

2024-07-14 08:43:23
字體:
供稿:網(wǎng)友

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

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

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

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

對應(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除以每個比n小比1大的自然數(shù)   if(n%i==0){//如果有能被整除的,則不是質(zhì)數(shù)    isPrime=false;   }  }  if(isPrime){//如果是質(zhì)數(shù),則打印出來   System.out.print(n+" ");   primeNumber++;//記錄質(zhì)數(shù)的個數(shù)   if(primeNumber%10==0)//輸出10個質(zhì)數(shù)后換行    System.out.println();  }}

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

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

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

對應(yīng)代碼是:

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

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

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

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

對應(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);//對range開根號  for(int i=2;i<=n;i++)//注意需要小于等于n   if(isPrime[i])//查看是不是已經(jīng)置false過了    for(int j=i;j*i<range;j++)//將是i倍數(shù)的位置置為false     isPrime[j*i]=false;  return isPrime;//返回一個boolean數(shù)組}

 

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


注:相關(guān)教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产一区二区三区四区五区在线 | 91九色视频在线播放 | 777午夜精品视频在线播放 | 97色在线观看免费视频 | 国产精品久久999 | 色污视频在线观看 | 欧美黄色一级片视频 | 色无极影院亚洲 | 色综合久久久久久久久久久 | 久久人添人人爽人人爽人人片av | 99精品国产在热久久婷婷 | 亚洲看片网 | 一分钟免费观看完整版电影 | 日韩视频www| 欧美a在线播放 | 玖玖视频精品 | 九九久久视频 | 亚洲视频欧美 | 在线成人免费网站 | 国产精品欧美久久久久一区二区 | 欧美一区在线观看视频 | 国产成人av在线播放 | 成人一区二区在线观看视频 | 成人小视频免费在线观看 | 成人h视频在线 | 精品一区二区三区日本 | 欧美在线观看视频网站 | 亚洲一区二区免费视频 | 特逼视频| 久久国产精品二国产精品 | 永久免费不卡在线观看黄网站 | www.国产免费 | 一级毛片看 | 亚洲一级电影在线观看 | 国产精品久久久久久久四虎电影 | 黄色免费播放网站 | 日本精品免费观看 | 法国性xxx精品hd专区 | 中文字幕亚洲视频 | 久久国产成人午夜av浪潮 | 亚洲男人天堂 |