• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            題目大意:判斷一個數字n是不是Carmichael number,所謂Carmichael number,滿足兩個條件:是合數;對于任意a(2<=a<=n-1),都有a^n mod n=a。
            只需要預處理篩素數和了解快速冪取模即可。
            以下是我的代碼:
            #include<stdio.h>
            #include
            <math.h>
            const long maxn=65007;
            bool isPrime[maxn];
            void get_prime()
            {
                
            long Prime[maxn],tot;
                
            for(long i=1;i<maxn;i++) isPrime[i]=true;
                isPrime[
            1]=false;
                tot
            =0;
                
            for(long i=2;i<maxn;i++)
                {
                   
            if(isPrime[i])
                   {
                      tot
            ++;Prime[tot]=i;
                   }
                   
            for(long j=1;j<=tot&&i*Prime[j]<maxn;j++)
                   {
                      isPrime[i
            *Prime[j]]=false;
                      
            if(i%Prime[j]==0break;
                   }
                }
            }
            long mod(long a,long n,long b)
            {
                
            if(n==1return a%b;
                
            long ans=mod(a,n/2,b);
                ans
            =(ans*ans)%b;
                
            if(n%2==1return ans*a%b;
                
            return ans;
            }
            bool check(long n)
            {
                
            for(long i=2;i<=n-1;i++)
                  
            if(mod(i,n,n)!=i)
                    
            return false;
                
            return true;
            }
            int main()
            {
                
            /*
                freopen("data.in","r",stdin);
                freopen("data.out","w",stdout);
                //
            */
                
            long n;
                get_prime();
                
            while(scanf("%ld",&n)==1)
                {
                   
            if(n==0break;
                   
            if(!isPrime[n]&&check(n))
                     printf(
            "The number %ld is a Carmichael number.\n",n);
                   
            else printf("%ld is normal.\n",n);
                }
            return 0;
            }


            posted on 2010-01-23 19:56 lee1r 閱讀(1009) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:數學/數論
            狠狠色婷婷久久一区二区| 久久av无码专区亚洲av桃花岛| 久久99国产综合精品免费| 狠狠色丁香久久婷婷综合五月 | 欧美精品乱码99久久蜜桃| yy6080久久| 久久精品国产亚洲av影院| 久久99国产精一区二区三区| 久久成人18免费网站| 久久久久人妻一区二区三区| 久久人人爽人人爽人人AV | 日产精品99久久久久久| 久久精品国产免费一区| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 69久久精品无码一区二区| 精品伊人久久大线蕉色首页| 久久久久久九九99精品| 久久久这里有精品中文字幕| 久久亚洲AV成人无码电影| 午夜精品久久久久9999高清| 精品久久久噜噜噜久久久| 午夜精品久久影院蜜桃| 国产一区二区三区久久| 亚洲午夜福利精品久久| 久久精品无码一区二区日韩AV| 日本欧美久久久久免费播放网| 久久综合成人网| 久久93精品国产91久久综合| 久久99精品久久久久婷婷| 色婷婷综合久久久中文字幕| 国产精品乱码久久久久久软件| 国内精品久久久久久久久电影网| 精品无码久久久久久尤物| 亚洲AV无码久久寂寞少妇| 婷婷久久精品国产| 亚洲国产香蕉人人爽成AV片久久 | 无码人妻久久一区二区三区免费 | 久久精品国产一区| 国产成人久久精品激情| 久久国产精品99精品国产| 亚洲综合伊人久久大杳蕉|