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

            M.J的blog

            algorithm,ACM-ICPC
            隨筆 - 39, 文章 - 11, 評論 - 20, 引用 - 0
            數(shù)據(jù)加載中……

            求N的階乘約數(shù)的個數(shù)

            先說一個定理:

                    若正整數(shù)n可分解為p1^a1*p1^a2*...*pk^ak
                    其中pi為兩兩不同的素數(shù),ai為對應指數(shù)
                    n的約數(shù)個數(shù)為(1+a1)*(1+a2)*....*(1+ak)
                    如180=2*2*3*3*5=2^2*3^2*5
                   180的約數(shù)個數(shù)為(1+2)*(1+2)*(1+1)=18個。

                   若求A/B的約數(shù)個數(shù),A可分解為p1^a1*p2^a2*...*pk^ak,B可分解為q1^b1*q1^b2*...*qk^bk,則A/B的約數(shù)個數(shù)            為(a1-b1+1)*(a2-b2+1)*(a3-b3+1)...*(ak-bk+1).

            然后說N的階乘:

            例如:20!
            1.先求出20以內(nèi)的素數(shù),(2,3,5,7,11,13,17,19)
            2.再求各個素數(shù)的階數(shù)
            e(2)=[20/2]+[20/4]+[20/8]+[20/16]=18;
            e(3)=[20/3]+[20/9]=8;
            e(5)=[20/5]=4;
            ...
            e(19)=[20/19]=1;
            所以
            20!=2^18*3^8*5^4*...*19^1

            解釋:
            2、4、6、8、10、12、14、16、18、20能被2整除
            4、8、12、16、20能被4整除(即被2除一次后還能被2整除)
            8、16能被8整除(即被2除兩次后還能被2整除)
            16能被16整除(即被2除三次后還能被2整除)
            這樣就得到了2的階。其它可以依次遞推。

            所以在求N的階乘質數(shù)因數(shù)個數(shù)時,從最小的質數(shù)開始,

            1 int cal(int n, int p) {

            2      if(n < p) return 0;

            3      else return n / p + cal(n / p, p);

            4 
            其中P是質數(shù),則該函數(shù)返回的就是N的階乘中可以表達成質數(shù)P的指數(shù)的最大值。原理如上。
            TOJ 2308的AC代碼:
             1 #include<iostream>
             2 
             3 #include<cmath>
             4 
             5 #define N 90
             6 
             7 #define M 450  
             8 
             9 using namespace std;
            10 
            11 int p[M+2]={0};
            12 
            13 int prime[N+2],l,q,t=1;  //求前90個素數(shù)
            14 
            15 void getprime(int n)
            16 
            17 {
            18     
            19     for(l=2;l<n;l++)
            20         
            21     {
            22         
            23         if(!p[l])
            24             
            25         {
            26             
            27             for(q=l+l;q<n;q+=l)
            28                 
            29             {
            30                 
            31                 p[q]=1;
            32                 
            33             }
            34             
            35             prime[t]=l;t++;
            36             
            37         }
            38         
            39       }
            40     
            41 }
            42 
            43 int cal(int n,int m)      //求N的階乘含質因數(shù)M的次數(shù)
            44 
            45 {
            46     if(m>n)
            47         
            48         return 0;
            49     
            50     else
            51         
            52         return n/m+cal(n/m,m);
            53     
            54 }
            55 int main()
            56 {
            57     int i,j,k,n;
            58     
            59     long long m;
            60     
            61     getprime(M);
            62     
            63     while(cin>>n>>k)
            64         
            65     {
            66         if(2*k>n)  k=n-k;
            67         
            68         for(i=1,m=1;prime[i]<=n,i<t;i++)
            69             
            70             m*=(cal(n,prime[i])-cal(k,prime[i])-cal(n-k,prime[i])+1);  
            71         
            72         cout<<m<<endl;
            73    
            74     }
            75 }

            posted on 2010-04-23 19:49 M.J 閱讀(524) 評論(0)  編輯 收藏 引用

            久久99国产精品久久久 | 国产精品内射久久久久欢欢| av色综合久久天堂av色综合在| 奇米影视7777久久精品人人爽| 亚洲国产一成人久久精品| 久久精品国产第一区二区三区 | 精品久久久久久久无码| 国产91色综合久久免费| 国产成人精品久久亚洲| A级毛片无码久久精品免费| 美女写真久久影院| 免费无码国产欧美久久18| 久久超乳爆乳中文字幕| 色婷婷狠狠久久综合五月| 亚洲精品白浆高清久久久久久| 国产精品欧美久久久久无广告| 国产成人无码精品久久久性色 | 久久人做人爽一区二区三区| 亚洲午夜久久久久久噜噜噜| 韩国三级中文字幕hd久久精品| 国产精品美女久久福利网站| 国产99久久久久久免费看| 无码人妻精品一区二区三区久久 | 日韩久久无码免费毛片软件| 91精品国产综合久久久久久| 久久99国产精品久久99小说 | 亚洲国产成人精品女人久久久 | 久久狠狠高潮亚洲精品| 国产精品久久久久久久久软件| 久久国产乱子伦精品免费午夜| 77777亚洲午夜久久多喷| 亚洲愉拍99热成人精品热久久| 欧美日韩中文字幕久久久不卡| 久久无码人妻一区二区三区午夜| 久久久国产99久久国产一| 99久久精品国产综合一区| 久久久久久久亚洲Av无码| 国产精品99久久久精品无码| 久久久国产99久久国产一| 国产精品99久久久精品无码| 免费一级欧美大片久久网|