• <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, 評(píng)論 - 1, 引用 - 0
            數(shù)據(jù)加載中……

            2011年7月26日

            [轉(zhuǎn)載]幾道與Gcd有關(guān)的題

            本文轉(zhuǎn)載自ara神牛的blog

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

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

            考慮到枚舉 i 可能會(huì)超時(shí), 我們可以反過來枚舉 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, 問題轉(zhuǎn)化為求 sigma(i), gcd(i, n / d) == 1. 可以發(fā)現(xiàn)如果 i n 互質(zhì), 那么 n – i n 也互質(zhì). 將互質(zhì)的數(shù)兩兩配對(duì)后答案就是 n / d * phi(n / d) / 2.

             

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

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

            枚舉 j 后轉(zhuǎn)化為 (I).

             

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

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

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

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

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

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

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

             

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

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

            枚舉質(zhì)數(shù) P 后轉(zhuǎn)化為 (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 的數(shù)量.

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

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

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

             

            Sol 2.

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

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

            時(shí)間復(fù)雜度 O(sqrt(n) * sqrt(n)) = O(n).

             

            (VII). Crash 的數(shù)字表格 (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), 我們只需要對(duì)于所有相同的 d, 計(jì)算出 sigma(i * j).

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

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

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

            根據(jù)容斥原理有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)..

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

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

            時(shí)間復(fù)雜度 O(sqrt(n) * sqrt(n)) = O(n).

             

            擴(kuò)展閱讀

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

            四道Gcd統(tǒng)計(jì)問題: http://hi.baidu.com/廣陵lonely/blog/item/6b00f8de2ca366b7cd11669e.html



            posted @ 2011-07-26 21:40 treeboy 閱讀(373) | 評(píng)論 (0)編輯 收藏

            2011年6月21日

            八中OJ

            [Sdoi2011]工作安排: 規(guī)模不大,工作安排.很容易想到費(fèi)用流,由于憤怒函數(shù)單調(diào)增,所以直接連邊.費(fèi)用作差
            [Sdoi2011]消耗戰(zhàn): 很綜合的一道題.可以看出來是樹中的最小割.兩種做法:1)增加一個(gè)匯點(diǎn),將每個(gè)詢問定點(diǎn)連匯,容量INF.實(shí)現(xiàn)好的link_cut tree維護(hù)最大流能跑過去.2)直接思維的話去掉的邊肯定是一些點(diǎn)的LCA到根的最小值.那么就把所有的點(diǎn)分組.用動(dòng)態(tài)規(guī)劃去做(單調(diào)棧維護(hù))
            2011.7.14多做題,多思考>_<
            [2010國(guó)家集訓(xùn)隊(duì)]拉拉隊(duì)排練:找前k長(zhǎng)的奇數(shù)長(zhǎng)的回文串的乘積.這是一個(gè)很經(jīng)典的后綴數(shù)組維護(hù)的題目,但是學(xué)習(xí)了twb神牛的神擴(kuò)展kmp解法.(回來用后綴數(shù)組寫一個(gè)^_^)
            [2010國(guó)家集訓(xùn)隊(duì)]布娃娃:給定一坨區(qū)間,找符合該區(qū)間的第k大值.添加事件點(diǎn),用一棵平衡樹維護(hù)每個(gè)布娃娃的魅力值.
            2010.7.25從數(shù)學(xué)夏令營(yíng)回來,晉級(jí)問題不大
            [2010國(guó)家集訓(xùn)隊(duì)]穩(wěn)定婚姻:先寫了一個(gè)暴力網(wǎng)絡(luò)流,然后總結(jié)增廣路的形式,膜拜我校的小同學(xué)

            posted @ 2011-06-21 10:49 treeboy 閱讀(778) | 評(píng)論 (0)編輯 收藏

            2011年6月7日

            Tyvj做題記錄

            [序列劃分] 直接O(N)貪心.很容易想到
            [菌落計(jì)算] 掃描線+線段樹維護(hù).利用前綴和的思想計(jì)算答案.要離散化
            [計(jì)算機(jī)檢修] heap
            [航線導(dǎo)航] POJ的原題(鳴謝:Foreverbell).設(shè)F[s][c]在s點(diǎn)有c的最小花費(fèi).維護(hù)這個(gè)東西就可以了

            posted @ 2011-06-07 21:56 treeboy 閱讀(364) | 評(píng)論 (1)編輯 收藏

            2011年5月29日

            SPOJ做題記錄

            GSS1:給定一個(gè)序列,要求求出一個(gè)區(qū)間[l,r]中最大的子段和.維護(hù)一棵線段樹,記錄每個(gè)子區(qū)間的總和,從左邊連續(xù)的最大和,右邊連續(xù)的最大和,區(qū)間的最大子段和.查詢的時(shí)候要注意轉(zhuǎn)移細(xì)節(jié).

            COURIER:狀態(tài)壓縮的動(dòng)態(tài)規(guī)劃.f[S][Bx]表示人已經(jīng)完成了S集合中的任務(wù),當(dāng)前在任務(wù)x的結(jié)束位置Bx時(shí)的mindist.
            f[S|(1<<y)][By]=min{f[S][Bx]+dist(Bx,Ay)+dist(Ay+By)} 最后掃描答案時(shí)注意還要回到源點(diǎn)

            posted @ 2011-05-29 14:08 treeboy 閱讀(279) | 評(píng)論 (0)編輯 收藏

            88久久精品无码一区二区毛片 | 97久久精品人人澡人人爽| 热re99久久精品国99热| 久久久久久国产精品无码超碰| 91精品国产综合久久精品| 国产精久久一区二区三区| 亚洲国产精品综合久久一线| 久久综合给合久久狠狠狠97色 | 伊色综合久久之综合久久| 狠狠精品久久久无码中文字幕| 人妻无码久久一区二区三区免费 | 久久WWW免费人成一看片| 91久久精品视频| 亚洲AV无码久久寂寞少妇| 久久久久99精品成人片| 久久精品国产亚洲av麻豆色欲| 久久亚洲视频| 国产精品青草久久久久福利99 | 亚洲午夜无码久久久久小说| 久久青草国产手机看片福利盒子| 久久久久亚洲av成人网人人软件| 91久久精品视频| 久久精品国产69国产精品亚洲| 伊人久久大香线蕉av一区| 久久综合狠狠综合久久97色| Xx性欧美肥妇精品久久久久久| 久久精品国产亚洲精品2020| 精品人妻伦九区久久AAA片69| 久久久精品国产亚洲成人满18免费网站| 国产成人久久精品区一区二区| 亚洲国产另类久久久精品小说 | 久久久91人妻无码精品蜜桃HD| 久久国产精品久久| 91精品国产色综合久久| 国产精品久久自在自线观看| 2021久久精品国产99国产精品| 狠狠色婷婷综合天天久久丁香 | 色欲综合久久躁天天躁| 91精品久久久久久无码| 精品综合久久久久久88小说| 国产精品美女久久久久av爽|