• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            是技術(shù),更是藝術(shù)

            一心編程,就沒(méi)有解決不了的問(wèn)題
            posts - 9, comments - 11, trackbacks - 0, articles - 0

            快速判斷素?cái)?shù)算法

            Posted on 2010-07-16 21:40 李熙建 閱讀(4270) 評(píng)論(3)  編輯 收藏 引用 所屬分類: 算法
                引理:如果 a 是一個(gè)大于1的整數(shù),而所有小于或等于根號(hào) a  的素?cái)?shù)都除不盡 a ,則 a 是素?cái)?shù)。
            理想的判斷素?cái)?shù)的方法應(yīng)該是將所有小于或等于根號(hào)n的素?cái)?shù)去除n,但是n是一個(gè)隨機(jī)大于1的整數(shù),小于這個(gè)數(shù)的平方根的素?cái)?shù)表不好給定。下面介紹的方法,本意是動(dòng)態(tài)的構(gòu)建素?cái)?shù)表,但是引入了很多冗余的除數(shù)。

            代碼:
            bool prime (int num)
            {
              
            if (num == 2 || num == 3 || num == 5)
                
            return true;
              
            if (num % 2 == 0 || num % 3 == 0 || num % 5 == 0 || num == 1)
                
            return false;

              unsigned 
            long c = 7;
              
            int maxc = int (sqrt (num));
              
            while (c <= maxc)
                
            {
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 4;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 2;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 4;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 2;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 4;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 6;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 2;
                  
            if (num % c == 0)
                    
            return false;
                  c 
            += 6;
                }

              
            return true;
            }

            分析:
              相對(duì)于sqrt(n)次除,上面的程序需要sqrt(n)*8/30次除,效率提升了15/4倍。
              自然數(shù)n,我們假設(shè)小于n的素?cái)?shù)數(shù)F(n),F(n)的分布規(guī)律為:當(dāng)n趨向于無(wú)窮大時(shí),F(xiàn)(n)/(x/logx) = 1;
                    所以,動(dòng)態(tài)的冗余度近似為:(sqrt(n)*4/15-x/logx)/sqrt(n)*4/15

            其他更好的判斷素?cái)?shù)的算法,希望你能給我留言或者寫在評(píng)論上,謝謝!

            Feedback

            # re: 快速判斷素?cái)?shù)算法  回復(fù)  更多評(píng)論   

            2011-06-02 20:47 by 某W
            這方法很強(qiáng)大~
            謝謝~

            # re: 快速判斷素?cái)?shù)算法  回復(fù)  更多評(píng)論   

            2011-08-01 09:19 by 李熙建
            @某W
            謝謝,拋磚引玉而已,期待你提出更優(yōu)秀的方法

            # re: 快速判斷素?cái)?shù)算法  回復(fù)  更多評(píng)論   

            2012-10-25 19:21 by aa
            理論依據(jù)是什么?
            亚洲午夜久久久久久噜噜噜| 久久w5ww成w人免费| 久久国产亚洲精品麻豆| 久久久久国产精品三级网| 久久综合视频网站| 国产精品18久久久久久vr| 久久无码国产| 东方aⅴ免费观看久久av| 国产精品久久久久…| 人妻无码精品久久亚瑟影视| 精品人妻久久久久久888| 久久无码专区国产精品发布| 国产精品久久国产精麻豆99网站| 思思久久精品在热线热| a级毛片无码兔费真人久久| 欧美日韩精品久久久免费观看| 欧美喷潮久久久XXXXx| 热re99久久6国产精品免费| 色综合合久久天天给综看| 久久久久亚洲精品男人的天堂| 久久人人爽人人爽人人片AV不| 久久国产视屏| 国产高清国内精品福利99久久| 少妇久久久久久被弄高潮| 久久99国产精品尤物| 久久久久久伊人高潮影院| 少妇内射兰兰久久| 欧美精品国产综合久久| 久久人人爽人爽人人爽av | 天天影视色香欲综合久久| www.久久热.com| 国产精品久久久福利| 2021精品国产综合久久| 久久久久亚洲AV无码网站| 久久久久成人精品无码中文字幕| 久久这里只有精品首页| 国产激情久久久久久熟女老人 | 久久青青草原精品国产| 7777精品久久久大香线蕉 | 精品久久久久久无码专区| 精品久久一区二区|