• <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年4月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(8)

            隨筆分類(74)

            隨筆檔案(68)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            最近又研究了線性篩素數方法的擴展,的確非常強大。
            經典的應用是線性時間篩歐拉函數和求約數個數。我想了一下線性時間篩約數和(積性函數),也是可行的。
            對于一個大于1的數n,可以寫成p1 ^ a1 * p2 ^ a2 * ... * pn ^ an,那么n的約數和就是(p1 ^ 0 + p1 ^ 1 + ... p1 ^ a1) * ... * (pn ^ 0 + ... + pn ^ an),由此就可以有遞推關系了:
            設f[i]表示i的約數和,e[i]表示i的最小素因子個數,t[i]表示(p1 ^ 0 + .. + p1 ^ a1),p1是t的最小素因子,a1是p1的冪次,這樣對于i * p[j],如果p[j]不是i的因子,那么根據積性條件,f[i*p[j]] = f[i] * (1 + p[j]),e[i] = 1,t[i] = 1 + p[j];如果p[j]是i的因子,那么相當于t[i]多了一項p1 ^ (a1 + 1),首先e[i]++,然后tmp = t[i],t[i] += p[j] ^ e[i],f[i*p[j]] = f[i] / tmp * t[i]。這樣也就做到了O(1)的時間計算出了f[i*p[j]]同時也計算出了附加信息。

            這種方法還可以繼續推廣,例如可以記錄i的最小素因子,這樣就可以做到O(log n)時間的素因子分解。

            posted on 2009-03-28 15:02 sdfond 閱讀(218) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm - Number Theory
            伊人情人综合成人久久网小说| 久久久精品人妻一区二区三区蜜桃| 91精品国产91久久| 人妻中文久久久久| 国产精品女同久久久久电影院| 91久久国产视频| 亚洲精品白浆高清久久久久久| 国产一区二区精品久久凹凸| 2020久久精品亚洲热综合一本| 久久精品中文字幕久久| 一本色道久久综合| 国产福利电影一区二区三区久久老子无码午夜伦不| 久久成人影院精品777| 四虎国产精品成人免费久久| 曰曰摸天天摸人人看久久久| 亚洲va久久久噜噜噜久久狠狠| 国产成人无码精品久久久久免费| 香蕉久久av一区二区三区| 久久影院亚洲一区| 久久99久久无码毛片一区二区| 2021久久国自产拍精品| 久久免费看黄a级毛片| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久亚洲精品无码观看不卡| 久久午夜无码鲁丝片| 精品熟女少妇AV免费久久| 久久精品无码一区二区日韩AV| 99久久久精品| A狠狠久久蜜臀婷色中文网| 欧美牲交A欧牲交aⅴ久久| 亚洲色大成网站WWW久久九九| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 一本大道久久东京热无码AV| 久久国产影院| 日韩欧美亚洲国产精品字幕久久久| 91秦先生久久久久久久| 很黄很污的网站久久mimi色| 99国产精品久久| 99久久国产综合精品成人影院| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲人AV永久一区二区三区久久|