• <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>
            隨筆 - 4, 文章 - 0, 評論 - 1, 引用 - 0
            數據加載中……

            [轉載]幾道與Gcd有關的題

            本文轉載自ara神牛的blog

            真的是好東西~
            (I). POJ 2480 Longge's problem (http://poj.org/problem?id=2480)

            題目大意: sigma(gcd(i, n)), 1 ≤ i ≤ n.

            考慮到枚舉 i 可能會超時, 我們可以反過來枚舉 d | n, 那么答案就是 sigma(d * phi(n / d)).

             

            (II). SPOJ LCMSUM (https://www.spoj.pl/problems/LCMSUM/)

            題目大意: sigma(lcm(i, n)), 1 ≤ i ≤ n.

            sigma(lcm(i, n)) = n * sigma(i / gcd(i, n)). 同上題一樣, 枚舉 d | n, 問題轉化為求 sigma(i), gcd(i, n / d) == 1. 可以發現如果 i n 互質, 那么 n – i n 也互質. 將互質的數兩兩配對后答案就是 n / d * phi(n / d) / 2.

             

            (III). SPOJ GCDEX (https://www.spoj.pl/problems/GCDEX/)

            題目大意: sigma(gcd(i, j)), 1 ≤ i < j ≤ n.

            枚舉 j 后轉化為 (I).

             

            (IV). POI Zap (http://www.zybbs.org/JudgeOnline/problem.php?id=1101)

            題目大意: 求有多少對 gcd(i, j) == d (i ≤ a, j ≤ b).

            a’ = a / d, b’ = b / d, 問題等價于求滿足 gcd(i, j) == 1的數量 (i ≤ a’, j ≤ b’).

            定義 F(k) gcd(i, j) k 的數量, G(k) gcd(i, j) == k 的數量.

            那么F(k) = (a’ / k) * (b’ / k)

            根據容斥原理有G(1) = F(1) – F(2) – F(3) - F(5) + F(6) …

            系數可以用篩法預處理, 同時觀察到對于連續的一段 k, F(k) 都是相同的,可以一起算出來. 通過預處理系數的前綴和可以在 O(sqrt(n)) 的時間算出 G(1).

             

            (V). SPOJ PGCD (https://www.spoj.pl/problems/PGCD/)

            題目大意: 求有多少 gcd(i, j) 是質數, 1 ≤ i ≤ a, 1 ≤ j ≤ b.

            枚舉質數 P 后轉化為 (IV).

             

            (VI). NOI 2010 能量采集 (http://www.zybbs.org/JudgeOnline/problem.php?id=2005)

            題目大意: sigma(gcd(i, j)), i ≤ a, j ≤ b.

            Sol 1.

            F[k] 為滿足 gcd(i, j) == k 的數量.

            那么F[k] = (a / k) * (b / k) – F[2k] – F[3k] – F[4k] …

            答案就是 sigma(i * F[i]).

            時間復雜度 O(n / 1 + n / 2 + n / 3 + …) = O(nlogn).

             

            Sol 2.

            枚舉 d = gcd(i, j), a’ = a / d, b’ = b / d, 那么問題轉化為求滿足 gcd(i, j) == 1(i ≤ a, j ≤ b) 的數量, 也就轉化為 (IV), 將這個數量記為 F(a, b).

            同時注意到對于一段連續的d, F(a’, b’) 都是一樣的, 可以一起算出來.

            時間復雜度 O(sqrt(n) * sqrt(n)) = O(n).

             

            (VII). Crash 的數字表格 (http://www.zybbs.org/JudgeOnline/problem.php?id=2154)

            題目大意: sigma(lcm(i, j)) (i ≤ a, j ≤ b).

            sigma(lcm(i, j)) = sigma(i * j / gcd(i, j))

            枚舉 d = gcd(i, j), 我們只需要對于所有相同的 d, 計算出 sigma(i * j).

            a’ = a / d, b’ = b / d, 那么問題轉化為求 F(a’, b’) = sigma(i * j) (gcd(i, j) == 1, i ≤ a’, j ≤ b’).

            Sum(a, b) = 1 * 1 + 1 * 2 + + a * b, 由等差數列的求和公式可得:

            Sum(a, b) = a * (a + 1) * b * (b + 1) / 4.

            根據容斥原理有F(a, b) =12 * Sum(a / 1, b / 1) - 22 * Sum(a / 2, b / 2) - 32 * Sum(a / 3, b / 3) - 52 * Sum(a / 5, b / 5) + 62 * Sum(a / 6, b / 6)..

            注意到對于一段連續的 i, Sum(a / i, b / i) 是相同的, Sum 的系數也可以通過篩法預處理出來.

            最后, 對于一段連續的 d, F(a’, b’) 也是相同的, 可以一起算出來.

            時間復雜度 O(sqrt(n) * sqrt(n)) = O(n).

             

            擴展閱讀

            線性篩法: http://www.shnenglu.com/sdfond/archive/2009/03/16/76775.html

            四道Gcd統計問題: http://hi.baidu.com/廣陵lonely/blog/item/6b00f8de2ca366b7cd11669e.html



            posted on 2011-07-26 21:40 treeboy 閱讀(393) 評論(0)  編輯 收藏 引用

            久久精品国产久精国产果冻传媒| 国产精品久久久久久久久软件| 久久久精品国产sm调教网站| 久久超乳爆乳中文字幕| 99久久99久久精品免费看蜜桃| 人人狠狠综合久久亚洲88| 四虎国产精品成人免费久久| 97久久婷婷五月综合色d啪蜜芽 | 久久精品国产亚洲AV嫖农村妇女| 久久91综合国产91久久精品 | 国产A级毛片久久久精品毛片| 久久夜色tv网站| 免费无码国产欧美久久18| 欧美综合天天夜夜久久| 三级三级久久三级久久| 亚洲国产二区三区久久| 亚洲va中文字幕无码久久不卡| 国产成人久久777777| 久久亚洲私人国产精品vA | 99国产精品久久| 久久香综合精品久久伊人| 国内精品久久久久久久涩爱| 精品国际久久久久999波多野| 久久人妻少妇嫩草AV蜜桃| 久久电影网一区| 精品国产乱码久久久久久郑州公司| 欧美成a人片免费看久久| 91精品国产色综久久| 久久精品国产亚洲沈樵| 久久99久久99精品免视看动漫| 久久精品人人做人人爽电影| 久久久久亚洲AV成人网| 色综合久久综合网观看| 美女写真久久影院| 狠狠精品久久久无码中文字幕| 国产V亚洲V天堂无码久久久| 久久精品毛片免费观看| 久久国产高潮流白浆免费观看| 99久久精品国产高清一区二区| AV色综合久久天堂AV色综合在| 久久99精品国产|