• <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>
            隨筆 - 87  文章 - 279  trackbacks - 0
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 217765
            • 排名 - 117

            最新評論

            閱讀排行榜

            評論排行榜

            歐拉函數一般形式:
            當 n 為素數時: phi(n) = n-1
            當 n 為合數時: phi(n) = n∏(1-1/p) 其中(p為n的素數因子)

            題目pku1091,要求我們求 x1..xn,m這樣的序列的個數,其中xi(1<=i<=n), 使 gcd(x1, ..,xn,m)=1;
            我們按歐拉函數的形式猜想如下方程:
            當 n 為素數時: phi(m,n) = m^n-1
            當 n 為合數時: phi(m,n) = m^n∏(1-1/p^n) 其中(p為n的素數因子)

            不給出嚴格數學證明(不會-_-),上兩式具體含義:
            當 n為素數 phi(m,n) = m^n-1 顯然成立
            當 n 為合數時 可以假象有一個m進制n位的數,然后其中一位有m的約數p的概率為1/p, 則n位同時有p的約數的概率就為(1-1/p^n), 運用乘法原理,可以得式 phi(m,n) = m^n∏(1-1/p^n)
             
            code:

            #include <iostream>
            using namespace std;

            typedef __int64 llong;
            const llong MAXN = 110000;
            llong tf[MAXN], su[MAXN], ns, num[MAXN], nn;

            void  init() {
                llong i, j;
                
            for (i=2; i<MAXN; i++) {
                    
            if (!tf[i]) {
                        su[ns
            ++]=i;
                        
            for (j=i*i; j<MAXN; j+=i) tf[j]=1;
                    }
                }
            }

            llong ppow(llong a, llong b) {
                llong ret
            =a;
                llong i;
                
            for (i=1; i<b; i++) ret *= a;
                return ret;
            }

            int main() {
                llong n, m, i, p;
                llong ans
            =0;
                init();
                
            while (scanf("%I64d%I64d"&n, &m)!=EOF) {
                    p
            =m; nn=0; ans=0;
                    
            for (i=0; i<ns; i++) {
                        
            if (p%su[i]==0) {
                            
            while (p%su[i]==0) p/=su[i];
                            num[nn
            ++]=su[i];
                        }
                        
            if (p==1) break;
                    }
                    
            if (!nn) {
                        ans 
            = ppow(m,n)-1;
                    } 
            else {
                        ans 
            = ppow(m,n);
                        
            for (i=0; i<nn; i++) {
                            ans 
            = ans/ppow(num[i],n)*(ppow(num[i],n)-1);
                        }
                    }
                    printf(
            "%I64d\n", ans);
                }
                return 
            0;
            }
            posted on 2007-09-02 22:57 閱讀(2501) 評論(4)  編輯 收藏 引用 所屬分類: 算法&ACM

            FeedBack:
            # re: 擴展的歐拉函數 pku1091 2007-09-18 09:41 nice
            這個公式好牛,類比的好強  回復  更多評論
              
            # re: 擴展的歐拉函數 pku1091[未登錄] 2007-10-07 10:35 beyond
            你好,常來你個Blog,故對你的網名很熟悉,近日在NUAA( Latin Stones 1110 )上看你做了一題歐拉定理得題,那題我沒有i想法,能把遞推公式還有代碼發給我,供學習參考嗎?非常感謝!我的郵箱是:beyondjjj@tom.com  回復  更多評論
              
            # re: 擴展的歐拉函數 pku1091 2007-10-07 20:43 
            @beyond
            -_-這題不會,我那時候想dp結果發現不行。。。  回復  更多評論
              
            # re: 擴展的歐拉函數 pku1091 2008-05-28 18:04 maik
            你上面的講解跟程序有出入哦...
            上面應該是判斷m是否為素數,且p應該是m的因子  回復  更多評論
              
            久久笫一福利免费导航 | 久久亚洲精品无码VA大香大香| 老司机国内精品久久久久| 日本久久久精品中文字幕| 国产精品青草久久久久福利99 | 久久精品这里热有精品| 99久久精品国产一区二区| 久久亚洲中文字幕精品一区四| 亚洲国产成人久久综合野外 | 成人综合伊人五月婷久久| 伊人久久免费视频| 久久亚洲AV成人无码| 国产精品久久久久久搜索| 精品久久人人妻人人做精品| 精品无码久久久久国产动漫3d| 久久精品国产亚洲AV电影| 久久国产成人午夜AV影院| 大香伊人久久精品一区二区| 久久精品人人做人人爽电影蜜月| 久久这里只有精品首页| 亚洲国产日韩欧美综合久久| 精品久久久久久久无码| 久久伊人色| 国产午夜精品理论片久久影视 | 精品久久久久香蕉网| 久久人妻少妇嫩草AV无码专区| 国内精品伊人久久久久| 久久精品视频一| A级毛片无码久久精品免费| 无码超乳爆乳中文字幕久久| 久久一本综合| 久久99久久成人免费播放| 亚洲第一极品精品无码久久| 久久久久97国产精华液好用吗| 国产综合久久久久| 亚洲国产精品一区二区久久hs| 办公室久久精品| 久久精品国产精品国产精品污| 日韩精品无码久久久久久| 亚洲国产成人久久笫一页| 香蕉99久久国产综合精品宅男自 |