• <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
            <2010年6月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            常用鏈接

            留言簿(8)

            隨筆分類(74)

            隨筆檔案(68)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

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

            附PKU 1811代碼:

            PKU 1811
            posted on 2009-04-03 20:06 sdfond 閱讀(717) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm - Number Theory
            国产亚洲精午夜久久久久久| 中文字幕亚洲综合久久菠萝蜜| 中文成人无码精品久久久不卡| 久久伊人五月天论坛| 久久精品免费全国观看国产| 久久香综合精品久久伊人| 99久久婷婷国产综合亚洲| 国产999精品久久久久久| 久久伊人亚洲AV无码网站| 久久亚洲精品国产精品| 91久久国产视频| 亚洲精品乱码久久久久久中文字幕| 国产午夜免费高清久久影院| 久久精品国产亚洲Aⅴ香蕉| 亚洲AV无码久久寂寞少妇| 久久精品国产亚洲麻豆| 久久精品久久久久观看99水蜜桃 | www.久久热| 久久丝袜精品中文字幕| 三上悠亚久久精品| 亚洲人成无码www久久久| 久久精品一区二区| 欧美日韩精品久久久久| 国产精品久久久久久久午夜片| 亚洲AV无码一区东京热久久| 久久久久久国产精品无码下载| 久久国产免费观看精品3| 久久天天婷婷五月俺也去| 99久久国产免费福利| 久久99精品国产麻豆| 国产成人综合久久精品红| 久久99热这里只有精品国产| 亚洲va久久久噜噜噜久久男同| 久久久久99精品成人片| 99久久国产热无码精品免费久久久久 | 久久福利资源国产精品999| 久久国产精品免费一区| 久久精品一区二区国产| 99久久久精品免费观看国产| 看久久久久久a级毛片| 亚洲国产一成人久久精品|