• <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
            題目大意是給出一個(gè)K和L,求在[2, L)范圍內(nèi)有沒有整數(shù)能整除K。
            K很大,L<=10^6。
            一開始我預(yù)處理了素?cái)?shù)表,然后枚舉[2, L)以內(nèi)的素?cái)?shù),用大整數(shù)求余的方法判斷是不是K的質(zhì)因子,TLE。
            將K改為萬進(jìn)制,溢出,WA。
            改成千進(jìn)制即可AC。
            以下是我的代碼:
            /*
             * Author:  lee1r
             * Created Time:  2011/8/25 10:29:17
             * File Name: poj2635.cpp
             
            */
            #include
            <iostream>
            #include
            <sstream>
            #include
            <fstream>
            #include
            <vector>
            #include
            <list>
            #include
            <deque>
            #include
            <queue>
            #include
            <stack>
            #include
            <map>
            #include
            <set>
            #include
            <bitset>
            #include
            <algorithm>
            #include
            <cstdio>
            #include
            <cstdlib>
            #include
            <cstring>
            #include
            <cctype>
            #include
            <cmath>
            #include
            <ctime>
            #define L(x) ((x)<<1)
            #define R(x) ((x)<<1|1)
            #define Half(x) ((x)>>1)
            #define Lowbit(x) ((x)&(-(x)))
            using namespace std;
            const int kInf(0x7f7f7f7f);
            const double kEps(1e-8);
            typedef unsigned 
            int uint;
            typedef 
            long long int64;
            typedef unsigned 
            long long uint64;

            bool scanf(int &num)
            {
                
            char in;
                
            while((in=getchar())!=EOF && (in>'9' || in<'0'));
                
            if(in==EOF) return false;
                num
            =in-'0';
                
            while(in=getchar(),in>='0' && in<='9') num*=10,num+=in-'0';
                
            return true;
            }

            const int kMaxn(1100000);

            int cnt,Prime[kMaxn+7];
            bool isPrime[kMaxn+7];

            void GetPrime()
            {
                cnt
            =0;
                
            for(int i=1;i<=kMaxn;i++)
                    isPrime[i]
            =true;
                
            for(int i=2;i<=kMaxn;i++)
                {
                    
            if(isPrime[i])
                        Prime[
            ++cnt]=i;
                    
            for(int j=1;j<=cnt && i*Prime[j]<=kMaxn;j++)
                    {
                        isPrime[i
            *Prime[j]]=false;
                        
            if(i%Prime[j]==0)
                            
            break;
                    }
                }
            }

            int Mod(int *a,int n,const int L)
            {
                
            int re(0);
                
            for(int i=1;i<=n;i++)
                    re
            =(re*1000+a[i]%L)%L;
                
            return re;
            }

            int main()
            {
                GetPrime();
                
                
            string S;
                
            int a[100],n;
                
            int L;
                
            while(cin>>S>>&& (S!="0" || L))
                {
                    n
            =0;
                    
            if(S.size()%3)
                    {
                        n
            ++;
                        a[n]
            =0;
                        
            for(int i=0;i<S.size()%3;i++)
                            a[n]
            =a[n]*10+S[i]-'0';
                    }
                    
            for(int i=S.size()%3;i<S.size();i+=3)
                    {
                        n
            ++;
                        a[n]
            =0;
                        
            for(int j=i;j<i+3;j++)
                            a[n]
            =a[n]*10+S[j]-'0';
                    }
                    
                    
            int ans(-1);
                    
            for(int i=1;Prime[i]<L;i++)
                        
            if(Mod(a,n,Prime[i])==0)
                        {
                            ans
            =Prime[i];
                            
            break;
                        }
                    
            if(ans==-1)
                        printf(
            "GOOD\n");
                    
            else
                        printf(
            "BAD %d\n",ans);
                }
                
                
            return 0;
            }
            posted on 2011-08-25 11:12 lee1r 閱讀(347) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:數(shù)學(xué)/數(shù)論
            亚洲国产二区三区久久| 久久久青草青青国产亚洲免观| 欧美久久久久久精选9999| 久久久久97国产精华液好用吗| 久久亚洲国产精品五月天婷| 一本一本久久a久久综合精品蜜桃| 亚洲午夜久久久影院| 国产99久久久久久免费看| 亚洲第一永久AV网站久久精品男人的天堂AV | 国产精品久久久久久久久久影院 | 人妻无码精品久久亚瑟影视| 无码超乳爆乳中文字幕久久| 免费一级欧美大片久久网 | 久久九九久精品国产免费直播| 久久久精品国产免大香伊| 国产精品女同一区二区久久| 久久精品国产亚洲av麻豆色欲 | 久久亚洲AV成人无码国产| 蜜桃麻豆www久久国产精品| 国产高潮国产高潮久久久| 中文成人久久久久影院免费观看| 久久国产乱子精品免费女| 日韩精品无码久久久久久| 青青草原综合久久大伊人导航| 久久综合中文字幕| 久久久久久久亚洲Av无码| 久久久久av无码免费网| 无码人妻久久一区二区三区蜜桃| 伊人久久免费视频| 久久精品www| 久久国产精品99精品国产987| 久久久久久久久久久久中文字幕| 亚洲日本久久久午夜精品| 久久亚洲电影| 久久久久久亚洲精品影院| 久久久久亚洲AV无码去区首| 美女久久久久久| 国产亚洲美女精品久久久2020| 久久99热这里只有精品66| 亚洲精品无码成人片久久| 狠狠色丁香久久婷婷综合五月|