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

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

PKU 2720 Last Digits

題目鏈接:http://poj.org/problem?id=2720
/*
題意:
    給定三個整數 b, n, 和 i, 定義函數 f(x) = b^f(x-1) 如果 x > 0, 并且 f(0)=1。
要求計算 f(i) 的最后n為十進制整數,并且要求輸出前導零。

解法:
    二分求冪 + 歐拉函數 + 素數篩選

思路:
    除非b等于1的時候,否則,這個數列的增長速度很快,所以直接暴力是行不通的,這
里我們用到數論的一個結論,a^b % c = a^ (b % phi(c) + phi(c)) % c,b < phi(c)。
其中phi(c)是c的歐拉函數,也就是小于等于c并且與之互質的數的個數。
    于是當b比較小的時候就可以直接采用二分求冪來做,當b很大的時候就利用這個結論
,可以迅速將指數降下來。
    這題是海量數據,如果每個數都直接算肯定會超時,我的做法是用一個數組保存下來
,而且保存的是n等于7的值,也就是保存了整數后7為,這樣可以少算6倍。最后再做處理
,注意前導零的處理。
*/


#include 
<iostream>

using namespace std;

#define maxn 3163
bool f[maxn];
int prime[maxn], size;
int ten[8];

void Init() {
    
int i, j;
    f[
0= f[1= 1;
    
for(i = 2; i < maxn; i++{
        
if(!f[i]) {
            prime[size
++= i;
            
for(j = i+i; j < maxn; j += i) {
                f[j] 
= 1;
            }

        }

    }

    ten[
0= 1;
    
for(i = 1; i <= 7; i++{
        ten[i] 
= ten[i-1* 10;
    }

}


int phi(int v) {
    
int i;
    
int ans = 1;
    
for(i = 0; i < size; i++{
        
if(!(v % prime[i])) {
            v 
/= prime[i];
            
while(!(v % prime[i])) {
                v 
/= prime[i];
                ans 
*= prime[i];
            }

            ans 
*= prime[i] - 1;

            
if(v == 1)
                
return ans;
        }

    }

    
return ans * (v - 1);
}


int Product_Mod(int a, int b, int mod) {
    
int S = 0;
    
while(b) {
        
if(b & 1{
            S 
= (S + a) % mod;            
        }

        b 
>>= 1;
        a 
= (a + a) % mod;
    }

    
return S;
}


#define ll __int64

int Exp_Mod(ll a, int b, int mod) {
    ll v 
= 1;
    
while(b) {
        
if(b & 1{
            v 
*= a;
            
if(v >= mod)
                v 
%= mod;
        }

        b 
>>= 1;
        a 
*= a;
        
if(a >= mod)
            a 
%= mod;
    }

    
return v;
}


int hash[101][101];
int F[101][101];
int dfs(int b, int n, int mod) {
    
if(n == 0)
        
return 1 % mod;
    
if(mod == 1)
        
return 0;
    
if(F[b][n] < 0{
        
int oula = phi(mod);
        
return Exp_Mod( b, dfs(b, n-1, oula) + oula, mod);
    }
else {
        
return F[b][n] % mod;
    }

}


int Test(int b, int ex) {
    
if(ex < 0)
        
return -1;

    
int i;
    
int sum = 1;
    
for(i = 0; i < ex; i++{
        sum 
*= b;
        
if(sum >= ten[7])
            
return -1;
    }

    
return sum;
}




int main() {
    Init();
    
int i, j;
    
int bew, n, mod, ans;
    memset(hash, 
-1sizeof(hash));

    
for(i = 1; i <= 100; i++{
        F[i][
0= 1;
        
for(j = 1; j <= 100; j++{
            F[i][j] 
= Test(i, F[i][j-1]);
        }

    }


    
while(scanf("%d"&bew) != EOF && bew) {
        scanf(
"%d %d"&n, &mod);

        
if(hash[bew][n] == -1{
            
if(bew == 1{
                ans 
= 1;
            }
else {
                ans 
= dfs(bew, n, ten[7]);
            }

            hash[bew][n] 
= ans;
        }

        ans 
= hash[bew][n] % ten[mod];

        
for(i = 1; i <= 7; i++{
            
if(ans < ten[i]) {
                
break;
            }

        }


        
for(i = mod-i; i ; i--{
            printf(
"0");
        }

        printf(
"%d\n", ans);
    }

    
return 0;
}

posted on 2011-04-07 20:02 英雄哪里出來 閱讀(1413) 評論(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>
            91久久久国产精品| 欧美在线观看视频一区二区三区| 久久超碰97中文字幕| 亚洲免费视频网站| 国产性做久久久久久| 久久人体大胆视频| 久久综合九色九九| 亚洲美女在线一区| 亚洲视频欧美视频| 国产视频一区欧美| 欧美成人免费大片| 欧美日韩精品在线视频| 亚洲欧美中文在线视频| 欧美资源在线观看| 亚洲国产影院| 一本久久a久久精品亚洲| 国产精品久久久久久久久久久久| 欧美制服丝袜第一页| 久久一区视频| 亚洲一区二区三区乱码aⅴ| 亚洲欧美日韩在线| 亚洲国产视频直播| 亚洲一区二区三区精品视频| 好看的av在线不卡观看| 亚洲欧洲一区二区三区| 国产乱理伦片在线观看夜一区| 麻豆国产精品一区二区三区 | 亚洲精品日产精品乱码不卡| 欧美特黄一级| 欧美xx69| 国产精品一区免费在线观看| 欧美成人久久| 国产欧美日韩免费| 亚洲国产欧美日韩另类综合| 国产精品毛片| 亚洲国产精品电影| 国产一区二区三区久久精品| 亚洲免费观看| 亚洲国产精品va| 亚洲欧美日本国产专区一区| 亚洲精品美女91| 久久国产精品久久国产精品| 亚洲无线观看| 欧美xart系列高清| 久久野战av| 国产精品老牛| 亚洲精品美女久久7777777| 国产一区二区三区在线免费观看| 99pao成人国产永久免费视频| 亚洲成人影音| 久久精品国产一区二区三区免费看| 一区二区三区精品| 欧美黄色一区| 欧美风情在线观看| 伊人天天综合| 久久国产精品免费一区| 欧美中文字幕视频| 国产精品视频yy9099| 一本色道久久88亚洲综合88| 亚洲毛片在线观看| 免费在线成人| 亚洲第一精品影视| 亚洲国产高清一区| 老司机67194精品线观看| 久久婷婷蜜乳一本欲蜜臀| 国产伦精品一区二区三区免费| 国产精品99久久不卡二区| 亚洲视频第一页| 欧美日韩在线精品一区二区三区| 亚洲人午夜精品免费| 99视频精品在线| 欧美日韩亚洲一区三区| 在线一区二区三区四区五区| 亚洲一区三区在线观看| 国产精品免费区二区三区观看| 亚洲手机成人高清视频| 西西人体一区二区| 国产日产欧美一区| 久久国产夜色精品鲁鲁99| 老司机凹凸av亚洲导航| 亚洲夫妻自拍| 欧美国产成人在线| av成人毛片| 久久www成人_看片免费不卡| 韩国精品久久久999| 久久午夜视频| 亚洲精品一区在线| 午夜在线播放视频欧美| 国产亚洲一区二区三区在线观看| 久久国内精品视频| 亚洲韩国青草视频| 亚洲免费在线观看| 国产综合精品一区| 免费在线欧美视频| 亚洲视频中文字幕| 久热精品视频在线观看一区| 亚洲另类在线视频| 国产精品女人久久久久久| 欧美在线观看网站| 亚洲国产欧美国产综合一区| 午夜精品久久久久久久蜜桃app| 国外成人在线视频| 欧美精品免费在线观看| 亚洲欧美日韩精品久久亚洲区| 女仆av观看一区| 中文日韩欧美| 尤物网精品视频| 国产精品jvid在线观看蜜臀| 久久久综合网| 在线一区二区日韩| 亚洲福利视频在线| 欧美自拍偷拍午夜视频| 亚洲精品专区| 精品成人一区二区三区| 欧美体内谢she精2性欧美| 久久这里只精品最新地址| 亚洲午夜激情网页| 亚洲国产精品久久久久秋霞不卡| 久久精品国产视频| 亚洲一区二区三区四区在线观看 | 亚洲永久在线| 91久久精品国产91久久性色tv| 国产精品一区二区三区免费观看| 欧美激情一区二区三区成人| 久久精品在线播放| 亚洲影院高清在线| 在线视频一区二区| 亚洲日本免费| 亚洲国产精品成人一区二区| 久久综合九色九九| 欧美有码在线视频| 亚洲欧美大片| 亚洲欧美日产图| 亚洲午夜女主播在线直播| 亚洲靠逼com| 亚洲另类在线视频| 亚洲国产成人av在线| 极品尤物av久久免费看| 国产午夜久久久久| 国产日本欧美一区二区三区| 国产精品萝li| 国产精品一区久久久| 国产精品区一区二区三区| 国产精品久久久久久av下载红粉| 欧美精品七区| 欧美日韩性生活视频| 欧美日韩在线视频一区二区| 欧美日韩高清免费| 欧美日韩一区在线播放| 欧美日韩免费观看一区三区 | 麻豆成人综合网| 蜜桃久久av| 欧美成年人网站| 欧美日本中文| 国产精品久久久久久久久久免费看 | 国产精品美女久久久久aⅴ国产馆| 欧美日韩亚洲三区| 国产精品成人观看视频国产奇米| 欧美性大战xxxxx久久久| 欧美视频在线一区二区三区| 国产精品极品美女粉嫩高清在线 | 狠狠色狠狠色综合日日五| 韩国亚洲精品| 亚洲欧洲精品一区二区三区| 99ri日韩精品视频| 中文av一区特黄| 久久动漫亚洲| 欧美黄网免费在线观看| 日韩视频精品| 亚洲欧美在线播放| 久久夜色精品国产| 欧美精品在线免费观看| 国产精品久久久久久av下载红粉 | 红桃视频亚洲| 亚洲另类在线一区| 亚洲欧美一区二区三区在线| 久久综合九色| 99re6这里只有精品视频在线观看| 亚洲综合欧美日韩| 久久男人资源视频| 欧美日韩另类综合| 韩日成人在线| 亚洲视频碰碰| 免费成人在线观看视频| 日韩亚洲视频在线| 久久久91精品国产| 欧美四级在线观看| 亚洲国产精品传媒在线观看| 亚洲一区二区动漫| 欧美成人激情视频| 亚洲小视频在线| 欧美承认网站| 国产在线精品自拍| 亚洲综合欧美日韩| 欧美激情麻豆| 久久精品一区二区国产| 国产精品美女久久福利网站| 日韩亚洲一区二区| 欧美不卡高清| 久久精品二区亚洲w码|