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

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

Pku 3209 From Pythagoras to …(數(shù)論)

問題描述:
給定一個(gè)數(shù),問它是否能夠表示成兩個(gè)整數(shù)的平方和。
解題思路:
費(fèi)馬平方和定理的表述是:奇素?cái)?shù)能表示為兩個(gè)平方數(shù)之和的充分必要條件是該素?cái)?shù)被4除余1。
于是一個(gè)素?cái)?shù)p = 4n+1或者p = 2則必定能表示成兩個(gè)平方數(shù)之和。
同樣可以推導(dǎo)出如果兩個(gè)數(shù)均能表示成兩個(gè)平方數(shù)之和,則他們的乘積必定能表示成兩個(gè)平方數(shù)之和:
p = a^2 + b^2;
q = c^2 + d^2;
p*q = (a^2 + b^2)(c^2 + d^2) = (ac)^2 + (ad)^2 + (bc)^2 + (bd)^2 = (ac + bd)^2 + (ac - bd)^2
只要將所求數(shù)分解素因子,然后對于每個(gè)素?cái)?shù)看是否滿足條件,一旦有一個(gè)素因子不滿足費(fèi)馬平方和定理則直接輸出"NO",全部滿足則輸出"YES"

代碼如下:

#include 
<iostream>
#include 
<cstdlib>
#include 
<cmath>
#define gcc 10007
typedef __int64 Int;
#define MAX ((Int)1<<63)-1

using namespace std;

Int p[
10= {2357111317192329};

Int Gcd(Int a, Int b)
{
    Int m 
= 1;
    
while(m)
    
{
        m 
= a % b;
        a 
= b;
        b 
= m;
    }

    
return a;
}


//計(jì)算a*b%n
inline Int Produc_Mod(Int a, Int b, Int mod)
{
    Int sum 
= 0;
    
while(b)
    
{
        
if(b & 1) sum = (sum + a) % mod;
        a 
= (a + a) % mod;
        b 
/= 2;
    }

    
return sum;
}


//計(jì)算a^b%n
inline Int Power(Int a, Int b, Int mod)
{
    Int sum 
= 1;
    
while(b)
    
{
        
if(b & 1) sum = Produc_Mod(sum, a, mod);
        a 
= Produc_Mod(a, a, mod);
        b 
/= 2;
    }

    
return sum;
}


//Rabin_Miller判素
bool Rabin_Miller(Int n)
{
    
int i, j, k = 0;
    Int u, m, buf;
    
//將n-1分解為m*2^k
    if(n == 2)
        
return true;
    
if(n < 2 || !(n & 1))
        
return false;
    m 
= n-1;
    
while(!(m & 1))
    
{
        k
++;
        m 
/= 2;
    }

    
for(i = 0; i < 9; i++)
    
{
        
if(p[i] >= n)
            
return true;

        u 
= Power(p[i], m, n);
        
if(u == 1)
            
continue;
        
for(j = 0; j < k; j++)
        
{
            buf 
= Produc_Mod(u, u, n);
            
//看是否有非平凡因子存在
            if(buf == 1 && u != 1 && u != n-1)
                
return false;
            u 
= buf;
        }

        
//如果p[i]^(n-1) % n != 1 那么 n為合數(shù)
        if(u-1)
            
return false;
    }

    
return true;
}


Int Pollard_rho(Int n)
{
    
while(1)
    
{
        
int i = 1;
        Int x 
= rand() % (n-1+ 1;
        Int y 
= x;
        Int k 
= 2;
        Int d;
        
do{
            i
++;
            d 
= Gcd(n + y - x, n);
            
if(d > 1 && d < n)
                
return d;
            
if(i == k)
                y 
= x, k *= 2;
            x 
= (Produc_Mod(x, x, n) + n - gcc) % n;
        }
while(y != x);
    }

}


Int prime[
10000];
int top;

void Prime_Divisor(Int key)
{
    
if( Rabin_Miller(key) )
    
{
        prime[ top 
++ ] = key;
    }
else
    
{
        Int buf 
= Pollard_rho(key);

        
if( Rabin_Miller(buf) ){
            prime[ top 
++ ] = buf;
        }
else{
            Prime_Divisor(buf);
        }



        
if( Rabin_Miller(key / buf) ){
            prime[ top 
++ ] = key / buf;
        }
else{
            Prime_Divisor(key 
/ buf);
        }

    }

}

int main()
{
    
int t, i;
    Int n;
    scanf(
"%d"&t);
    
while(t--)
    
{
        scanf(
"%I64d"&n);
        
if(n < 0)
            printf(
"NO\n");
        
else if(n == 0 || n == 1)
            printf(
"YES\n");
        
else 
        
{
            top 
= 0;
            Prime_Divisor(n);

            
for(i = 0; i < top; i++)
                
if( prime[i] != 2 && (prime[i] - 1% 4 )
                    
break;
            
if(i < top)
                printf(
"NO\n");
            
else
                printf(
"YES\n");
        }

    }

}

posted on 2009-02-10 21:04 英雄哪里出來 閱讀(389) 評論(0)  編輯 收藏 引用 所屬分類: ACM

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久人人97超碰人人澡爱香蕉| 欧美a级片一区| 欧美11—12娇小xxxx| 亚洲欧美日本精品| 亚洲人成欧美中文字幕| 国产日韩在线视频| 欧美无砖砖区免费| 欧美高清视频一区二区| 亚洲一区欧美一区| 亚洲精品乱码久久久久| 久久久久久久97| 午夜在线精品偷拍| 在线综合亚洲| 亚洲精品网站在线播放gif| 激情成人综合| 国户精品久久久久久久久久久不卡| 欧美在线免费视屏| 亚洲一区二区三区国产| 亚洲精品你懂的| 久久久噜噜噜久久中文字幕色伊伊 | 国产精品爽爽ⅴa在线观看| 欧美不卡在线| 久久亚洲国产精品一区二区| 午夜一区在线| 国产精品99久久久久久宅男| 日韩写真视频在线观看| 亚洲国产免费看| 亚洲第一福利视频| 欧美国产三区| 亚洲国产高潮在线观看| 欧美激情一区二区久久久| 猛男gaygay欧美视频| 久久影音先锋| 男男成人高潮片免费网站| 久久一本综合频道| 免费成人你懂的| 免费亚洲一区二区| 欧美韩日亚洲| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲最新色图| 一本大道久久a久久精二百| 亚洲最黄网站| 一区二区三区日韩精品| 99精品国产一区二区青青牛奶| 国产欧美日韩一区二区三区| 国产欧美亚洲一区| 国色天香一区二区| 亚洲高清三级视频| 日韩视频在线观看免费| 一本色道久久综合亚洲精品小说| 国产精品美女久久久久av超清| 久久九九国产精品| 久久久美女艺术照精彩视频福利播放| 日韩亚洲精品电影| 在线视频精品一区| 午夜亚洲福利| 久久精品亚洲国产奇米99| 久久综合狠狠| 欧美日韩系列| 国产欧美欧洲在线观看| 一区二区三区在线观看视频| 亚洲人精品午夜| 亚洲午夜精品久久久久久app| 亚洲国产一区视频| 亚洲老板91色精品久久| 亚洲一级免费视频| 久久精品女人| 亚洲高清不卡av| 中国女人久久久| 久久精品日产第一区二区三区| 亚洲综合日韩在线| 久久精品卡一| 欧美美女喷水视频| 国产日韩欧美亚洲一区| 亚洲电影激情视频网站| 99热免费精品| 久久精品理论片| 亚洲人成在线播放网站岛国| 亚洲男人的天堂在线观看| 久久综合中文色婷婷| 国产精品国产三级国产 | 国产视频一区在线观看| 亚洲高清免费视频| 午夜精品区一区二区三| 久久夜色精品国产欧美乱极品| 欧美在线视频免费| 亚洲国产精品免费| 亚洲一区成人| 欧美精品成人在线| 国产一区二区福利| 亚洲一区二区三区激情| 免费美女久久99| 亚洲女ⅴideoshd黑人| 欧美精品videossex性护士| 国产伊人精品| 亚洲女同同性videoxma| 亚洲福利一区| 欧美在线视频一区| 欧美亚州一区二区三区| 亚洲精品国产精品久久清纯直播| 亚洲激情在线视频| 欧美在线视频一区| 亚洲免费成人| 欧美大片在线观看一区| 国产综合久久久久久鬼色| 亚洲欧美电影院| 亚洲欧洲日本mm| 久久综合影视| 国产综合亚洲精品一区二| 午夜精品久久久久99热蜜桃导演| 久久精品电影| 亚洲影视九九影院在线观看| 欧美精品二区三区四区免费看视频| 欧美精品激情在线| 亚洲第一页在线| 久久天天躁狠狠躁夜夜av| 亚洲一区二区三区高清| 欧美日韩在线观看一区二区| 91久久极品少妇xxxxⅹ软件| 看片网站欧美日韩| 久久国产精品久久久| 国产欧美在线视频| 亚洲欧美视频一区| 亚洲午夜性刺激影院| 欧美视频观看一区| 亚洲综合电影| 一本色道久久99精品综合| 欧美日韩亚洲高清一区二区| 洋洋av久久久久久久一区| 亚洲人成网站精品片在线观看 | 麻豆精品在线视频| 伊人久久婷婷色综合98网| 久久女同互慰一区二区三区| 欧美在线日韩在线| 黄色成人av网站| 欧美不卡视频一区| 欧美成人一区二区在线| 在线观看成人av| 欧美aa在线视频| 美女精品一区| 亚洲伦理久久| 一区二区三区毛片| 国产精品男女猛烈高潮激情| 亚欧美中日韩视频| 欧美一区二区视频网站| 一区视频在线| 欧美福利影院| 欧美日韩精品久久| 亚洲欧美日韩久久精品| 欧美一区二区性| 亚洲国产国产亚洲一二三| 亚洲高清影视| 欧美性猛交一区二区三区精品| 亚洲激情精品| 亚洲精品1234| 国产精品久久久久久久app| 久久成人精品| 久久躁日日躁aaaaxxxx| 一级成人国产| 小处雏高清一区二区三区| 伊人成人在线| 亚洲老司机av| 国产欧美日韩在线视频| 欧美成年人网站| 欧美视频网站| 久久久最新网址| 欧美区亚洲区| 久久精品一区蜜桃臀影院| 免费成人黄色| 亚洲欧美日韩国产综合精品二区| 亚洲国产成人不卡| 国产精品久久激情| 蜜臀久久99精品久久久久久9| 亚洲自拍偷拍视频| 亚洲国产精品电影在线观看| 夜夜嗨av一区二区三区网站四季av | 午夜老司机精品| 久久精品亚洲| 亚洲一区国产视频| 久久久99国产精品免费| 中日韩高清电影网| 久久国产精品久久久久久电车| 国产日韩欧美成人| 欧美电影免费观看| 国产精品久久久久久亚洲调教| 亚洲午夜一级| 久久久久久夜| 亚洲一区二区欧美日韩| 久久久久久久欧美精品| 亚洲小说区图片区| 嫩草国产精品入口| 久久精品国产久精国产爱| 欧美日韩一区二区在线| 欧美大片免费看| 国产亚洲成人一区| 亚洲视频免费观看| 一本久久a久久精品亚洲| 久久久久高清| 欧美在线视频观看免费网站| 欧美日韩免费在线|