欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Lucas定理學(xué)習(xí)小記

系統(tǒng) 2161 0

(1)Lucas定理:p為素?cái)?shù),則有:

(2)證明:?n=(ak...a2,a1,a0)p = (ak...a2,a1)p*p + a0?=? [n/p]*p+a0,m=[m/p]*p+b0其次,我們知道,對(duì)任意質(zhì)數(shù)p有(1+x)^p=1+(x^p)(mod p) 。我們只要證明這個(gè)式子:C(n,m)=C([n/p],[m/p]) * C(a0,b0)(mod p),那么就可以用歸納法證明整個(gè)定理。對(duì)于模p而言,我們有下面的式子成立:

Lucas定理學(xué)習(xí)小記

上式左右兩邊的x的某項(xiàng)x^m(m<=n)的系數(shù)對(duì)模p同余。其中左邊的x^m的系數(shù)是 C(n,m)。 而由于a0和b0都小于p,因此右邊的x^m 一定是由 x^([m/p]*p) 和 x^b0 (即i=[m/p] , j=b0 )?相乘而得 因此有:C(n,m)=C([n/p],[m/p]) * C(a0,b0)? (mod p)。

(3)拓展應(yīng)用:上面的p是素?cái)?shù),那么不是素?cái)?shù)怎么辦呢?若不是素?cái)?shù),將p分解質(zhì)因數(shù),將C(n,m)分別按照(1)中的方法求對(duì)p的質(zhì)因數(shù)的模,然后用中國(guó)剩余定理合并。比如計(jì)算C(10,3)%14。C(10,3)=120,14有兩個(gè)質(zhì)因數(shù)2和7,120%2=0,120%7=1,這樣用(2,0)(7,1)找到最小的正整數(shù)8即是答案,即C(10,3)%14=8。注意,這里只適用于p分解完質(zhì)因數(shù)后每個(gè)質(zhì)因數(shù)只出現(xiàn)一次,例如12=2*2*3就不行,因?yàn)?出現(xiàn)了兩次。若p分解完質(zhì)因數(shù)后,含有某個(gè)質(zhì)因數(shù)出現(xiàn)多次,比如C(10,3)%98,其中98=2*7*7,此時(shí)就要把7*7看做一個(gè)數(shù),即:120%2=0,120%49=22,用(2,0)(49,22)和中國(guó)剩余定理得到答案22,即C(10,3)%98=22。此時(shí),你又會(huì)有疑問(wèn),C(10,3)%49不也是模一個(gè)非素?cái)?shù)嗎?此時(shí)不同的是這個(gè)非素?cái)?shù)不是一般的非素?cái)?shù),而是某個(gè)素?cái)?shù)的某次方。下面(4)介紹如何計(jì)算C(n,m)%p^t(t>=2,p為素?cái)?shù))。

(4)計(jì)算C(n,m)%p^t。我們知道,C(n,m)=n!/m!/(n-m)!,若我們可以計(jì)算出n!%p^t,我們就能計(jì)算出m!%p^t以及(n-m)!%p^t。我們不妨設(shè)x=n!%p^t,y=m!%p^t,z=(n-m)!%p^t,那么答案就是x*reverse(y,p^t)*reverse(z,p^t)(reverse(a,b)計(jì)算a對(duì)b的乘法逆元)。那么下面問(wèn)題就轉(zhuǎn)化成如何計(jì)算n!%p^t。比如p=3,t=2,n=19,

n!=1*2*3*4*5*6*7*8*?……*19

? ?=[1*2*4*5*7*8*… *16*17*19]*(3*6*9*12*15*18)

? ?=[1*2*4*5*7*8*… *16*17*19]*3^6(1*2*3*4*5*6)

然后發(fā)現(xiàn)后面的是(n/p)!,于是遞歸即可。前半部分是以p^t為周期的[1*2*4*5*7*8]=[10*11*13*14*16*17](mod 9)。下面是孤立的19,可以知道孤立出來(lái)的長(zhǎng)度不超過(guò) p^t,于是暴力即可。那么最后剩下的3^6啊這些數(shù)怎么辦呢?我們只要計(jì)算出n!,m!,(n-m)!里含有多少個(gè)p(不妨設(shè)a,b,c),那么a-b-c就是C(n,m)中p的個(gè)數(shù),直接算一下就行。

至此整個(gè)計(jì)算C(n,m)%p(p為任意數(shù))的問(wèn)題完美解決。下面給出代碼:

?

      
        i64 POW(i64 a,i64 b,i64 mod)

{

    i64 ans=1;

    while(b)

    {

        if(b&1) ans=ans*a%mod;

        a=a*a%mod;

        b>>=1;

    }

    return ans;

}



i64 POW(i64 a,i64 b)

{

    i64 ans=1;

    while(b)

    {

        if(b&1) ans=ans*a;

        a=a*a;

        b>>=1;

    }

    return ans;

}





i64 exGcd(i64 a,i64 b,i64 &x,i64 &y)

{

    i64 t,d;

    if(!b)

    {

        x=1;

        y=0;

        return a;

    }

    d=exGcd(b,a%b,x,y);

    t=x;

    x=y;

    y=t-a/b*y;

    return d;

}



bool modular(i64 a[],i64 m[],i64 k)

{

    i64 d,t,c,x,y,i;



    for(i=2;i<=k;i++)

    {

        d=exGcd(m[1],m[i],x,y);

        c=a[i]-a[1];

        if(c%d) return false;

        t=m[i]/d;

        x=(c/d*x%t+t)%t;

        a[1]=m[1]*x+a[1];

        m[1]=m[1]*m[i]/d;

    }

    return true;

}







i64 reverse(i64 a,i64 b)

{

    i64 x,y;

    exGcd(a,b,x,y);

    return (x%b+b)%b;

}



i64 C(i64 n,i64 m,i64 mod)

{

    if(m>n) return 0;

    i64 ans=1,i,a,b;

    for(i=1;i<=m;i++)

    {

        a=(n+1-i)%mod;

        b=reverse(i%mod,mod);

        ans=ans*a%mod*b%mod;

    }

    return ans;

}



i64 C1(i64 n,i64 m,i64 mod)

{

    if(m==0) return 1;

    return C(n%mod,m%mod,mod)*C1(n/mod,m/mod,mod)%mod;

}



i64 cal(i64 n,i64 p,i64 t)

{

    if(!n) return 1;

    i64 x=POW(p,t),i,y=n/x,temp=1;

    for(i=1;i<=x;i++) if(i%p) temp=temp*i%x;

    i64 ans=POW(temp,y,x);

    for(i=y*x+1;i<=n;i++) if(i%p) ans=ans*i%x;

    return ans*cal(n/p,p,t)%x;

}



i64 C2(i64 n,i64 m,i64 p,i64 t)

{

    i64 x=POW(p,t);

    i64 a,b,c,ap=0,bp=0,cp=0,temp;

    for(temp=n;temp;temp/=p) ap+=temp/p;

    for(temp=m;temp;temp/=p) bp+=temp/p;

    for(temp=n-m;temp;temp/=p) cp+=temp/p;

    ap=ap-bp-cp;

    i64 ans=POW(p,ap,x);

    a=cal(n,p,t);

    b=cal(m,p,t);

    c=cal(n-m,p,t);

    ans=ans*a%x*reverse(b,x)%x*reverse(c,x)%x;

    return ans;

}



//計(jì)算C(n,m)%mod

i64 Lucas(i64 n,i64 m,i64 mod)

{

    i64 i,t,cnt=0;

    i64 A[205],M[205];

    for(i=2;i*i<=mod;i++) if(mod%i==0)

    {

        t=0;

        while(mod%i==0)

        {

            t++;

            mod/=i;

        }

        M[++cnt]=POW(i,t);

        if(t==1) A[cnt]=C1(n,m,i);

        else A[cnt]=C2(n,m,i,t);

    }

    if(mod>1)

    {

        M[++cnt]=mod;

        A[cnt]=C1(n,m,mod);

    }

    modular(A,M,cnt);

    return A[1];

}


      
    

?

?

Lucas定理學(xué)習(xí)小記


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产亚洲精品久久无亚洲 | 精品视频久久 | a网站在线观看 | 欧美在线一区视频 | 精品国产一区二区三区香蕉沈先生 | 777奇米视频| 日韩国产精品一区二区三区 | 国产精品久久人妻无码网站蜜臀 | 奇米第四色在线观看 | 国产午夜免费福利 | 天天干影视 | 中文字幕 国产精品 | 日本无卡码免费一区二区三区 | 国产电影精品 | 色爱区综合| 欧美xxxx狂喷水喷水 | 中文字幕精品一区二区三区精品 | a爱片| 亚洲一区二区在线 | 国产合集福利视频在线视频 | 日韩欧美一区二区在线观看 | 精品国产一区二区三区久久久 | 91麻豆精品国产91久久久更新资源速度超快 | 一级黄色片毛片 | 国产精品区一区二区三 | 色久影院 | 国产后式a一视频 | 小优视频为爱而生懂你更多茄子 | 久久精品男人的天堂 | 久久99精品视免费看 | 久久一er精这里有精品 | 日本伊人色综合网站 | 日韩男女做性高清在线观看 | 夜精品A片观看无码一区二区 | 91视频免费观看高清观看完整 | 久久99国产精一区二区三区 | 成人福利在线 | 久久精品99| 五月婷婷久 | 久久久久九九九九 | 日韩在线观看中文字幕 |