找质数算法
????????{
????????????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é)
- 上一篇: 现共收到 5 个分组,其目的地址分别为:
- 下一篇: 使用QuickCHM软件轻松编译CHM格