日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

找质数算法

發(fā)布時間:2025/3/15 61 豆豆
生活随笔 收集整理的這篇文章主要介紹了 找质数算法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
我們知道,對于一個給定的數(shù)判斷該數(shù)是不是質(zhì)數(shù),很簡單,只需要對其開根號,然后循環(huán)取模即可: public?bool?IsPrime(int?number)
????????{
????????????
if?(number?<?2)
????????????{
????????????????
return?true;
????????????}
????????????
else
????????????{
????????????????
for?(int?i?=?2;?i?<=?Math.Sqrt(number);?i++)
????????????????{
????????????????????
if?(number?%?i?==?0)
????????????????????{
????????????????????????
return?false;
????????????????????}
????????????????}
????????????}
????????????
return?true;
????????}

?????但是,對于一個給定的整數(shù),怎樣計算出小于該整數(shù)的所有素數(shù)呢?比較常見的是采用Sieve of Eratosthenes算法,它的基本思想是這樣:

?????由于一個合數(shù)總是可以分解成若干個質(zhì)數(shù)的乘積,那么如果把質(zhì)數(shù)(最初只知道2是質(zhì)數(shù))的倍數(shù)都去掉,那么剩下的就是質(zhì)數(shù)了。例如要查找100以內(nèi)的質(zhì)數(shù),首先2是質(zhì)數(shù),把2的倍數(shù)去掉;此時3沒有被去掉,可認(rèn)為是質(zhì)數(shù),所以把3的倍數(shù)去掉;再到5,再到7,7之后呢,因為8,9,10剛才都被去掉了,而100以內(nèi)的任意合數(shù)肯定都有一個因子小于10(100的開方,可參考前面判斷質(zhì)數(shù)的算法),所以,去掉,2,3,5,7的倍數(shù)后剩下的都是質(zhì)數(shù)了。

?????具體實現(xiàn),我們通過設(shè)置兩個數(shù)組,一個bool數(shù)組crossedOut,用來標(biāo)識對應(yīng)下標(biāo)的數(shù)字是不是質(zhì)數(shù),如果i是質(zhì)數(shù),crossedOut[i]=false,否則crossedOut[i]=true。那么劃掉i可以表示成crossedOut[i]=true。還有一個int型數(shù)組是result,用來存儲符合要求的素數(shù)。具體實現(xiàn)如下:

public?class?PrimeGenerator
????{
????????
private?static?bool[]?crossedOut;
????????
private?static?int[]?result;

????????
public?static?int[]?GeneratePrimeNumbers(int?maxValue)
????????{
????????????
if?(maxValue?<?2)
????????????{
????????????????
return?new?int[0];
????????????}
????????????
else
????????????{
????????????????UncrossIntegersUpTo(maxValue);
????????????????CrossOutMultiples();
????????????????PutUncrossedIntegersIntoResult();
????????????????
return?result;
????????????}
????????}

????????
private?static?void?UncrossIntegersUpTo(int?maxValue)
????????{
????????????crossedOut?
=?new?bool[maxValue?+?1];
????????????
for?(int?i?=?2;?i?<?crossedOut.Length;?i++)
????????????{
????????????????crossedOut[i]?
=?false;
????????????}
????????}

????????
private?static?void?PutUncrossedIntegersIntoResult()
????????{
????????????result?
=?new?int[NumberOfUncrossedIntegers()];
????????????
for?(int?j?=?0,?i?=?2;?i?<?crossedOut.Length;?i++)
????????????{
????????????????
if(NotCrossed(i))
????????????????{
????????????????????result[j
++]?=?i;
????????????????}
????????????}
????????}

????????
private?static?int?NumberOfUncrossedIntegers()
????????{
????????????
int?count?=?0;
????????????
for?(int?i?=?2;?i?<?crossedOut.Length;?i++)
????????????{
????????????????
if?(NotCrossed(i))
????????????????{
????????????????????count
++;
????????????????}
????????????}
????????????
return?count;
????????}

????????
private?static?void?CrossOutMultiples()
????????{
????????????
int?limit?=?DetermineIterationLimit();
????????????
for?(int?i?=?2;?i?<=?limit;?i++)
????????????{
????????????????
if?(NotCrossed(i))
????????????????{
????????????????????CrossOutputMultiplesOf(i);
????????????????}
????????????}
????????}

????????
private?static?int?DetermineIterationLimit()
????????{
????????????
double?iterationLimit?=?Math.Sqrt(crossedOut.Length);
????????????
return?(int)iterationLimit;
????????}

????????
private?static?void?CrossOutputMultiplesOf(int?i)
????????{
????????????
for?(int?multiple?=?2?*?i;?multiple?<?crossedOut.Length;?multiple?+=?i)
????????????{
????????????????crossedOut[multiple]?
=?true;
????????????}
????????}

????????
private?static?bool?NotCrossed(int?i)
????????{
????????????
return?crossedOut[i]?==?false;
????????}????
????}


?

轉(zhuǎn)載于:https://www.cnblogs.com/lemonade/archive/2008/12/10/1352121.html

總結(jié)

以上是生活随笔為你收集整理的找质数算法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。