• <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>

            是技術,更是藝術

            一心編程,就沒有解決不了的問題
            posts - 9, comments - 11, trackbacks - 0, articles - 0

            快速判斷素數算法

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

            代碼:
            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;
            }

            分析:
              相對于sqrt(n)次除,上面的程序需要sqrt(n)*8/30次除,效率提升了15/4倍。
              自然數n,我們假設小于n的素數數F(n),F(n)的分布規律為:當n趨向于無窮大時,F(n)/(x/logx) = 1;
                    所以,動態的冗余度近似為:(sqrt(n)*4/15-x/logx)/sqrt(n)*4/15

            其他更好的判斷素數的算法,希望你能給我留言或者寫在評論上,謝謝!

            Feedback

            # re: 快速判斷素數算法  回復  更多評論   

            2011-06-02 20:47 by 某W
            這方法很強大~
            謝謝~

            # re: 快速判斷素數算法  回復  更多評論   

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

            # re: 快速判斷素數算法  回復  更多評論   

            2012-10-25 19:21 by aa
            理論依據是什么?
            久久精品国产亚洲Aⅴ蜜臀色欲| 国产成人精品久久亚洲| 久久久久久精品免费免费自慰| 香蕉久久永久视频| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 伊人色综合久久天天网| 亚洲∧v久久久无码精品| 久久精品国产免费一区| 久久伊人精品一区二区三区| 久久w5ww成w人免费| 久久久久国产精品麻豆AR影院 | 久久久中文字幕| 精品久久人人爽天天玩人人妻| 久久青青草原国产精品免费| 香蕉久久影院| 精品久久久久久无码人妻热| 国产精品久久久久影院色| 久久亚洲AV无码精品色午夜麻豆| 久久青青草原精品影院| 久久精品中文闷骚内射| 色8久久人人97超碰香蕉987| 亚洲精品国精品久久99热| 青青青青久久精品国产h久久精品五福影院1421 | 久久91精品久久91综合| 久久国产精品成人影院| 久久久久99精品成人片欧美 | 国产精品久久久久免费a∨| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久婷婷综合中文字幕| 国产成人精品免费久久久久| 久久综合九色综合网站| 久久精品国产亚洲av麻豆色欲| 精品久久久久久国产潘金莲| 精品久久久久久久无码 | 国产精久久一区二区三区| 国产福利电影一区二区三区久久老子无码午夜伦不 | 亚洲AⅤ优女AV综合久久久| 久久精品国产AV一区二区三区 | 久久久久久国产精品无码下载 | 97精品依人久久久大香线蕉97| 欧洲成人午夜精品无码区久久 |