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

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

            先說(shuō)一個(gè)定理:

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

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

            然后說(shuō)N的階乘:

            例如:20!
            1.先求出20以?xún)?nèi)的素?cái)?shù),(2,3,5,7,11,13,17,19)
            2.再求各個(gè)素?cái)?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

            解釋?zhuān)?br>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的階乘質(zhì)數(shù)因數(shù)個(gè)數(shù)時(shí),從最小的質(zhì)數(shù)開(kāi)始,

            1int cal(int n, int p) {
            2     if(n < p) return 0;
            3     else return n / p + cal(n / p, p);
            4}

            其中P是質(zhì)數(shù),則該函數(shù)返回的就是N的階乘中可以表達(dá)成質(zhì)數(shù)P的指數(shù)的最大值。原理如上。

            下面附上TOJ 2308的AC代碼:


            #include<iostream>
            #include
            <cmath>
            using namespace std;
            #define N 90
            #define M 450  
            int p[M+2]={0};
            int prime[N+2],l,q,t=1;          //求前90個(gè)素?cái)?shù)
            void getprime(int n)
            {
               
            for(l=2;l<n;l++)
               
            {
                   
            if(!p[l])
                   
            {
                        
            for(q=l+l;q<n;q+=l)
                        
            {
                            p[q]
            =1;
                        }

                        prime[t]
            =l;t++;
                   }

               }

            }

            int cal(int n,int m)   //求N的階乘含質(zhì)因數(shù)M的次數(shù)
            {
               
            if(m>n)
                  
            return 0;
               
            else
                  
            return n/m+cal(n/m,m);
            }

            int main()
            {
               
            int i,j,k,n;
               
            long long m;
               getprime(M);
               
            while(cin>>n>>k)
               
            {
                  
            if(2*k>n)  k=n-k;
                  
            for(i=1,m=1;prime[i]<=n,i<t;i++)
                      m
            *=(cal(n,prime[i])-cal(k,prime[i])-          cal(n-k,prime[i])+1);  
                  cout
            <<m<<endl;
               
               }

            }

            posted on 2010-04-21 23:04 M.J 閱讀(3080) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): ACM-ICPC

            亚洲AV伊人久久青青草原| 国产精品99久久久久久董美香| 亚洲欧美成人久久综合中文网 | 亚洲午夜久久久久久噜噜噜| 亚洲国产天堂久久综合| 午夜精品久久久久久毛片| 久久精品国产亚洲av水果派| 国产精品日韩深夜福利久久| 久久夜色精品国产www| 亚洲av伊人久久综合密臀性色 | 亚洲第一极品精品无码久久| 狠狠狠色丁香婷婷综合久久五月 | 99久久99久久| 欧美一区二区久久精品| 国产一久久香蕉国产线看观看| 久久久久亚洲精品男人的天堂| 人妻少妇久久中文字幕| 色8激情欧美成人久久综合电| 亚洲午夜久久久久久久久电影网 | 伊人久久精品线影院| 亚洲人成网亚洲欧洲无码久久| 国产99久久精品一区二区| 91精品无码久久久久久五月天| 久久精品国产久精国产一老狼| 狠狠色丁香婷婷久久综合不卡| 一本大道久久东京热无码AV| 999久久久国产精品| 精品久久久久久久久中文字幕| 2021最新久久久视精品爱 | 精品一区二区久久| 午夜久久久久久禁播电影| 精品久久久久久久久免费影院| 美女写真久久影院| 99久久精品国产麻豆| 国产精品99久久久精品无码| 亚洲国产精品无码久久久久久曰| 久久久久婷婷| 欧美激情一区二区久久久| 2021最新久久久视精品爱| 伊人久久无码中文字幕| 狠狠色婷婷久久一区二区|