青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數據加載中……

ZJU 3108 Last Digit

題目鏈接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=2984

/*
題意:
    給出一個長度為N(N <= 1000000)的串,要求求出所有串的不重復排列的方案。
輸出方案數的最后一個非零位。

題解:
    組合數學 + 數論

思路:
    首先將所有字符歸類,相同的放在一起計數,然后就是一個組合問題了,可以
想象成L個抽屜,然后一類一類插入,比如有A1個'a',那么就是C(L, A1)種方案,
還有L-A1個位置,繼續下一步,如果有A2個'b'那么下一趟就是C(L-A1, A2)。將所
有的組合數相乘就是答案了。
    但是這題要求求的是答案的最后一個非零位,于是問題需要轉化一下,每次不
能直接將C(n, m)求出來,可以這樣想,導致一個數末幾尾有0的條件是這個數中有
至少一對2和5,C(n, m) = n! / m! / (n-m)!,用F[x]來記錄x的階乘中 2和5的個
數以及其它數的乘積,那么就可以把C(n, m)中其它數的乘積求出來:
ans = X[n] * X[m] * Inv[ X[n-m] ];
其中X[v] 表示v的階乘中其它數的乘積,Inv[v]表示v對于10的逆。
    所有的組合數求完之后,將剩下的2和5匹配掉,多余部分再乘到答案上即可。
*/



#include 
<iostream>
#include 
<cstring>
#include 
<cstdio>

using namespace std;

int hash[26];
char str[1000001];

int exp(int a, int b, int& x, int& y) {
    
int q;
    
if(b == 0{
        q 
= a; x = 1; y = 0;
        
return q;
    }

    q 
= exp(b, a%b, x, y);
    
int tmp = x;
    x 
= y;
    y 
= tmp - a/* y;
    
return q;
}


int inv(int v, int m) {
    
int x, y;
    exp(v, m, x, y);
    
return (x % m + m) % m;
}


struct Triple {
    
int num2, num5, other_product;
    Triple() 
{
        num2 
= num5 = 0;
        other_product 
= 1;
    }

    Triple(
int _2, int _5, int _p) {
        num2 
= _2;
        num5 
= _5;
        other_product 
= _p;
    }

}
;
Triple tp[
1000010];

Triple Go(
int n) {
    
return tp[n];
}


int AccPro = 1;

Triple C(
int n, int m) {
    Triple U, D[
2];
    U 
= Go(n);
    D[
0= Go(m);
    D[
1= Go(n - m);

    U.num2 
-= D[0].num2 + D[1].num2;
    U.num5 
-= D[0].num5 + D[1].num5;

    AccPro 
= AccPro * D[0].other_product * D[1].other_product % 10;
    
return U;
}


int Binary(int a, int b, int c) {
    
if(!b)
        
return 1 % c;
    
int tmp = Binary(a*a%c, b/2, c);
    
if(b & 1)
        tmp 
= tmp * a % c;
    
return tmp;
}


int main() {
    
int i;
    
for(i = 2; i < 1000001; i++{
        tp[i] 
= tp[i-1];

        
int val = i;
        
while(val % 2 == 0{
            val 
/= 2;
            tp[i].num2 
++;
        }

        
while(val % 5 == 0{
            val 
/= 5;
            tp[i].num5 
++;
        }

        
        tp[i].other_product 
*= val;
        tp[i].other_product 
%= 10;
    }


    
while(scanf("%s", str) != EOF) {
        memset(hash, 
0sizeof(hash));
        
int len = strlen(str);
        
for(i = 0; i < len; i++{
            hash[ str[i] 
- 'a' ] ++;
        }

        Triple ans;
        AccPro 
= 1;
        
for(i = 0; i < 26; i++{
            
if(hash[i]) {
                Triple X 
= C(len , hash[i]);
                
                ans.num2 
+= X.num2;
                ans.num5 
+= X.num5;
                ans.other_product 
= ans.other_product * X.other_product % 10;

                len 
-= hash[i];
            }

        }

        AccPro 
= inv(AccPro, 10);

        
int as = 1;

        
if(ans.num2 < ans.num5) {
            ans.num5 
-= ans.num2;
            
as = ans.other_product * Binary(5, ans.num5, 10* AccPro % 10;
        }
else {
            ans.num2 
-= ans.num5;
            
as = ans.other_product * Binary(2, ans.num2, 10* AccPro % 10;
        }



        printf(
"%d\n"as);
    }

    
return 0;
}

posted on 2011-04-15 14:19 英雄哪里出來 閱讀(923) 評論(0)  編輯 收藏 引用 所屬分類: 數學

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            激情欧美一区二区三区在线观看 | 亚洲少妇中出一区| 国内精品久久久久久久果冻传媒| 国产欧美一区二区视频| 国产啪精品视频| 国模精品娜娜一二三区| 尤物yw午夜国产精品视频明星| 亚洲国产欧美日韩精品| 日韩视频一区二区三区在线播放| 在线亚洲欧美| 久久亚洲国产精品日日av夜夜| 免费久久久一本精品久久区| 欧美激情欧美狂野欧美精品 | 欧美激情精品久久久六区热门 | 美女图片一区二区| 欧美日韩美女一区二区| 国产精品免费电影| 在线国产欧美| 亚洲永久视频| 欧美大片免费观看| 亚洲天堂av图片| 久久天天狠狠| 国产精品自拍视频| 亚洲蜜桃精久久久久久久| 性欧美精品高清| 亚洲第一天堂av| 亚洲视频一二| 免费亚洲电影在线观看| 国产精品日韩在线一区| 亚洲欧洲久久| 久久成人一区| 日韩视频久久| 噜噜噜在线观看免费视频日韩| 欧美日本国产视频| 激情欧美亚洲| 欧美在线免费观看亚洲| 亚洲精品久久嫩草网站秘色| 久久一二三区| 国产一区二区中文字幕免费看| 一区二区国产精品| 欧美.www| 久久久av毛片精品| 国产日韩欧美a| 亚洲自拍高清| 亚洲视频精选| 国产精品高精视频免费| 99精品久久免费看蜜臀剧情介绍| 麻豆国产精品一区二区三区| 欧美一区二区成人| 国产一区二区精品在线观看| 香蕉久久国产| 午夜精品久久99蜜桃的功能介绍| 欧美性天天影院| 一区二区三区福利| 亚洲精品视频二区| 欧美另类在线播放| 9久草视频在线视频精品| 亚洲国产精品国自产拍av秋霞| 麻豆久久婷婷| 亚洲理论在线观看| 亚洲麻豆一区| 国产精品久久一卡二卡| 亚洲欧美伊人| 午夜在线观看欧美| 国内自拍一区| 亚洲高清免费在线| 欧美日韩理论| 午夜精品久久一牛影视| 亚洲自拍偷拍福利| 国产日韩欧美日韩大片| 欧美在线一二三区| 性欧美在线看片a免费观看| 国产三区精品| 农村妇女精品| 欧美日韩成人在线视频| 亚洲在线国产日韩欧美| 中文在线资源观看网站视频免费不卡| 欧美日韩小视频| 欧美一区二区三区视频| 欧美自拍偷拍| 亚洲精品欧美日韩专区| aa级大片欧美三级| 国产欧美不卡| 欧美肥婆bbw| 国产精品久久二区二区| 欧美诱惑福利视频| 免费在线欧美视频| 亚洲永久字幕| 久久永久免费| 亚洲自拍都市欧美小说| 久久蜜桃精品| 亚洲一区二区三区午夜| 久久国产精品久久久久久电车| 亚洲日本电影| 亚洲欧美精品一区| 亚洲九九爱视频| 欧美在线视频观看| 一级日韩一区在线观看| 欧美专区18| 午夜视频久久久| 欧美激情按摩在线| 久久精品国产清高在天天线| 欧美人交a欧美精品| 久久精品一级爱片| 欧美精品在线一区二区三区| 国产一区在线播放| 99这里只有久久精品视频| 亚洲欧美高清| 亚洲精品免费在线播放| 亚洲在线一区| 亚洲精品偷拍| 欧美制服丝袜| 欧美一区中文字幕| 欧美日韩一二三区| 久久综合伊人77777麻豆| 国产精品欧美日韩一区二区| 亚洲人成7777| 亚洲人午夜精品| 狂野欧美一区| 久久蜜臀精品av| 国产欧美精品在线播放| 久久精品女人天堂| 国产精品老女人精品视频| 亚洲国产日韩一级| 激情国产一区二区| 香蕉久久夜色精品| 亚洲综合视频1区| 欧美日韩免费观看一区二区三区| 欧美在线观看一区| 欧美偷拍另类| 一区二区三区 在线观看视频| 亚洲精品国产拍免费91在线| 久久深夜福利免费观看| 鲁鲁狠狠狠7777一区二区| 欧美性开放视频| 99re视频这里只有精品| aa级大片欧美三级| 欧美日韩国产综合视频在线观看中文 | 久久蜜桃香蕉精品一区二区三区| 国产乱码精品一区二区三区五月婷| 日韩视频永久免费| 亚洲一区二区高清| 国产精品对白刺激久久久| 夜夜精品视频一区二区| 亚洲午夜小视频| 国产精品美腿一区在线看| 99精品欧美一区| 亚洲欧美日韩一区| 国产深夜精品福利| 久久高清一区| 欧美成人国产一区二区| 亚洲狼人综合| 国产精品久久福利| 久久福利毛片| 91久久精品日日躁夜夜躁国产| 亚洲成人影音| 欧美日本在线看| 亚洲一区二区毛片| 久久久噜噜噜久久中文字幕色伊伊| 在线看日韩av| 国产精品v片在线观看不卡| 亚洲欧美日本国产专区一区| 玖玖玖免费嫩草在线影院一区| 亚洲第一精品影视| 欧美天堂亚洲电影院在线观看| 欧美一级片一区| 亚洲国产精品成人综合色在线婷婷| 中文精品视频| 狠狠久久婷婷| 欧美日韩在线一区| 久久久久久亚洲精品不卡4k岛国| 亚洲国产精品999| 欧美综合第一页| 日韩午夜剧场| 国内揄拍国内精品久久| 欧美日韩视频在线一区二区 | 欧美精品不卡| 午夜日韩在线观看| 亚洲精品美女91| 老司机精品视频网站| 亚洲天堂免费在线观看视频| 好看的亚洲午夜视频在线| 欧美另类一区二区三区| 久久久免费精品视频| 在线亚洲免费| 在线视频观看日韩| 国产精品人成在线观看免费| 噜噜噜久久亚洲精品国产品小说| 亚洲午夜久久久久久久久电影院| 欧美好吊妞视频| 久久久精品国产免费观看同学| 在线一区亚洲| 136国产福利精品导航| 国产精品第三页| 欧美电影免费| 欧美伊人久久久久久午夜久久久久| 亚洲精品一区二区在线| 亚洲第一黄网| 欧美激情免费观看| 亚洲第一网站|