• <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>

            fzu 1775 Counting Binary Trees

            Posted on 2009-11-24 00:03 王之昊 閱讀(599) 評論(2)  編輯 收藏 引用 所屬分類: 數學
                感謝AC牛的幫助~~
                這道題是說給你一個n, 求有多少棵不同的二叉樹滿足其節點數不超過n.(n <= 100,000 ) 結果太大模上 m  (m < 10^9)
                我們已經很熟悉節點數為 n 的不同的二叉樹數目是catalan數 Cn. 枚舉每個 Ci % m (0 < i <= n)是顯然的.
                但是怎么來算Ci % m 呢?
                1   C[i+1] = 2*(2*i+1)/(i+2)*C[i]; 但是m不是素數, 我們怎么處理除法???
                2   單獨算 C[i+1]用素因子指數表示的方法(p1^a1 * p2^a2 * ...*pn^an)。可以解決這個問題,但是慢
                于是分成兩部分,跟 m 有關的素因子用 2 做, 跟 m 無關的素因子用 1 做,這樣就解決了。

            Feedback

            # re: fzu 1775 Counting Binary Trees   回復  更多評論   

            2010-09-05 10:54 by lisongs1
            能再講仔細點嗎 該怎么計算 ?是要把C[n]用p1^a1 * p2^a2 * ...*pn^an的方式紀錄下來嗎?

            # re: fzu 1775 Counting Binary Trees   回復  更多評論   

            2010-09-10 13:16 by 王之昊
            @lisongs1
            比如算C(10,3) % 4 等價于 [ (10*9*8) / (3*2*1) ] % 4.
            然后又等價于 { [ 2^4 * (5*9*1) ] / [ 2^1 * (3*1*1) ] } % 4,相當于把和4不互素的因子提出來,這種因子是很少的。
            然后得到 [ (5*9*1) / (3*1*1) ] % 4 直接用模或者求逆算就可以了

            posts - 26, comments - 7, trackbacks - 0, articles - 17

            Copyright © 王之昊

            久久久久亚洲av综合波多野结衣| AV狠狠色丁香婷婷综合久久| 久久综合五月丁香久久激情| 国产成人精品久久综合| 欧美国产精品久久高清| 影音先锋女人AV鲁色资源网久久| 亚洲成色WWW久久网站| 成人免费网站久久久| 久久久久亚洲精品男人的天堂| 色综合久久夜色精品国产| 亚洲午夜久久久久久久久久| 久久夜色tv网站| 久久www免费人成看片| 99久久国产亚洲高清观看2024| 伊人久久无码精品中文字幕| 精品久久久久久久久中文字幕| 午夜福利91久久福利| 国产成人久久激情91| 久久亚洲精品成人无码网站| 99热精品久久只有精品| 日本人妻丰满熟妇久久久久久| 国产综合成人久久大片91| 蜜臀av性久久久久蜜臀aⅴ| 久久久久久毛片免费看 | 天天躁日日躁狠狠久久| 国产精品免费久久久久久久久 | 26uuu久久五月天| 少妇高潮惨叫久久久久久| 久久久精品国产亚洲成人满18免费网站| 日日噜噜夜夜狠狠久久丁香五月| 色播久久人人爽人人爽人人片aV| 亚洲国产精品久久久久婷婷老年| 狠狠色狠狠色综合久久| 色综合久久夜色精品国产| 人妻无码久久精品| 久久亚洲国产精品五月天婷| 国产成人久久精品麻豆一区| 一本一道久久精品综合| 99久久精品免费国产大片| 久久亚洲精品视频| 伊人久久综在合线亚洲2019|