• <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>
            隨筆 - 68  文章 - 57  trackbacks - 0
            <2009年4月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

            留言簿(8)

            隨筆分類(74)

            隨筆檔案(68)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

              大整數(shù)的快速質(zhì)因子分解,用到pollard-rho啟發(fā)式算法。
              算法導(dǎo)論上介紹pollard-rho介紹得比較詳細(xì),由于小因子的循環(huán)節(jié)長度很小,通過倍增步長,pollard-rho能夠很快的找到一個大整數(shù)的一個較小的素因子p,書中說復(fù)雜度在O(sqrt(p))內(nèi),用的什么概率的分析方法,不懂。實(shí)際中pollard-rho的速度還是很快的,當(dāng)然可能出現(xiàn)死循環(huán)。
              這個題目要利用pollard-rho找到一個數(shù)的最小素因子,因此還需要Miller-Rabin測試來輔助。原來寫的那個Miller-Rabin很快掛掉了,因為沒有用到二次探測,判不出來Carmichael數(shù)。如果x ^ 2 = 1 (mod n),如果n是質(zhì)數(shù),那么x只能是1和n - 1;二次探測就是利用這個定理來進(jìn)行檢測。
              POJ的論壇里面更有牛人列出了N多Carmichael數(shù),真不知道他怎么找到的。最初怎么也不知道二次探測加在哪里好,后來參考網(wǎng)上一位大牛的代碼,它的方法是計算a ^ b % n的時候,先將b折半到一個奇數(shù)b'為止,計算a ^ b',然后倍增b',同時進(jìn)行二次檢測,想想覺得很有道理,因為如果x ^ 2 = 1 mod n成立的話,那么(x ^ 2) ^ 2 = 1 mod n也成立。
              這個題目還有一個trick就是模能達(dá)到2 ^ 54,如果這樣計算一個數(shù)平方的時候,即使long long也會溢出。后來發(fā)現(xiàn)可以用快速冪取模的思想弄個"快速積取模",同樣將b表示成二進(jìn)制的形式,倍增的同時加到結(jié)果上就行了。這樣每次運(yùn)算的數(shù)范圍都在2 ^ 54以內(nèi),并且都是加操作,不會溢出了。
              POJ上還有一個用pollard-rho做的題是PKU 2429,這個比Prime Test還惡,因為這個題目是徹徹底底進(jìn)行factorization,而且之后還要枚舉一下找最優(yōu)解,總之我的代碼非常的長,而且這個題目數(shù)據(jù)范圍2 ^ 63,必須用unsigned long long才能過。我的代碼中間出現(xiàn)了一些減操作,都要特殊處理一下。最后還犯了個低級錯誤,函數(shù)返回值寫錯了,找了好幾遍才找出來。

            附PKU 1811代碼:

            PKU 1811
            posted on 2009-04-03 20:06 sdfond 閱讀(722) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm - Number Theory
            久久99精品久久久久久噜噜| 97久久精品无码一区二区| 国产无套内射久久久国产| 国产99久久久国产精免费| 久久午夜无码鲁丝片午夜精品| 久久激情亚洲精品无码?V| 久久精品久久久久观看99水蜜桃| 亚洲伊人久久成综合人影院 | 亚洲狠狠综合久久| 国产伊人久久| 久久精品国产亚洲AV忘忧草18| 久久综合给合久久狠狠狠97色69 | 无码人妻久久一区二区三区免费| 国产精品禁18久久久夂久 | www亚洲欲色成人久久精品| 一级女性全黄久久生活片免费| 色综合久久无码中文字幕| 国产成人精品久久亚洲高清不卡| 久久精品国产亚洲AV香蕉| 国产成人精品久久亚洲高清不卡| 欧美黑人又粗又大久久久| 久久久噜噜噜久久| 精品一区二区久久久久久久网站| 久久人人爽人人澡人人高潮AV| …久久精品99久久香蕉国产 | 久久夜色精品国产噜噜亚洲AV| 国内精品久久久久久中文字幕| 久久综合久久自在自线精品自 | 婷婷久久久亚洲欧洲日产国码AV | 亚洲欧美日韩精品久久亚洲区| 精品久久香蕉国产线看观看亚洲| 久久久久人妻一区二区三区| 久久免费视频6| 草草久久久无码国产专区| 99久久精品国产免看国产一区| 欧美伊人久久大香线蕉综合| 久久九九免费高清视频| 国产精品99久久久久久www| 久久91精品国产91久久户| 久久亚洲私人国产精品| 欧美噜噜久久久XXX|