一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - Java求質(zhì)數(shù)的幾種常用算法分析

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

2021-06-26 13:21Wonder Java教程

這篇文章主要介紹了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),稱為質(zhì)數(shù)。

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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ù)整除的話,那它肯定是合數(shù),即不是質(zhì)數(shù)。所以判斷一個(gè)數(shù)是否是質(zhì)數(shù),只需判斷它是否能被小于它開(kāi)跟后后的所有數(shù)整除,這樣做的運(yùn)算就會(huì)少了很多,因此效率也高了很多。

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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類型的數(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)平方),這樣的話把不是質(zhì)數(shù)的位置上置為false了,剩下的全是質(zhì)數(shù)了,挑著是true的打印出來(lái)就行了。

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

?
1
2
3
4
5
6
7
8
9
10
11
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ù)組
}

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

原文鏈接:http://blog.sina.com.cn/s/blog_622e77cc0100n5lm.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国内老司机精品视频在线播出 | 亚洲国产精品成人综合久久久 | 亚洲精品国产成人 | 成人精品网| 韩国漂亮美女三级在线观看 | 亚洲精品久久久久久婷婷 | 2020国产精品亚洲综合网 | 国产一级特黄aa大片在线 | 亚洲成人黄色网址 | 国产a不卡片精品免费观看 国产aaa伦理片 | 美女扒开两腿露出尿口的视频 | 共妻高h | 18videossex性欧美69 | 99久久er这里只有精品17 | 午夜无码国产理论在线 | 成人1234| 天天插伊人 | 日本hd18 | 丁香五香天堂网 | 天天插在线视频 | 91网站入口 | 女张腿男人桶羞羞漫画 | 国产香蕉一区二区在线网站 | 色噜噜 男人的天堂在线观看 | 91中文在线 | 日本高清免费不卡在线播放 | 国产suv精品一区二区四区三区 | 四虎成人免费大片在线 | 成人免费淫片95视频观看网站 | 调教麻麻成贱m | 欧美高清乌克兰精品另类 | 成人网免费视频 | 婷婷日韩 | 波多在线 | 精品一成人岛国片在线观看 | 色婷婷综合久久久中文字幕 | 国产成人盗拍精品免费视频 | 欧美一区二区三区精品 | 日韩欧美三级视频 | 久久九九久精品国产尤物 | 四虎在线免费播放 |