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

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

Pku 3209 From Pythagoras to …(數論)

問題描述:
給定一個數,問它是否能夠表示成兩個整數的平方和。
解題思路:
費馬平方和定理的表述是:奇素數能表示為兩個平方數之和的充分必要條件是該素數被4除余1。
于是一個素數p = 4n+1或者p = 2則必定能表示成兩個平方數之和。
同樣可以推導出如果兩個數均能表示成兩個平方數之和,則他們的乘積必定能表示成兩個平方數之和:
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
只要將所求數分解素因子,然后對于每個素數看是否滿足條件,一旦有一個素因子不滿足費馬平方和定理則直接輸出"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;
}


//計算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;
}


//計算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為合數
        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 英雄哪里出來 閱讀(386) 評論(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>
            亚洲视屏在线播放| 乱码第一页成人| 亚洲黄色成人| 国产性色一区二区| 久久琪琪电影院| 亚洲综合国产激情另类一区| 亚洲黄色在线| 亚洲第一视频| 亚洲国产精品电影| 欧美刺激午夜性久久久久久久| 久久国产精彩视频| 国产深夜精品福利| 久久免费少妇高潮久久精品99| 午夜精品久久久久久久白皮肤| 一本大道久久a久久精品综合| 亚洲人被黑人高潮完整版| 亚洲国产综合在线看不卡| 亚洲第一搞黄网站| 欧美国产日本在线| 亚洲国产综合在线看不卡| 欧美激情第一页xxx| 最新成人av在线| 一本色道久久综合亚洲精品婷婷| 9久re热视频在线精品| 久久免费午夜影院| 亚洲女人小视频在线观看| 午夜电影亚洲| 久久精品国产成人| 免费成人你懂的| 亚洲高清视频在线观看| 亚洲三级免费| 亚洲欧美精品在线| 老司机凹凸av亚洲导航| 欧美日本成人| 国产欧美精品日韩精品| 亚洲第一网站免费视频| 亚洲人成在线观看| 亚洲女同在线| 乱人伦精品视频在线观看| 亚洲高清在线播放| 欧美电影免费观看大全| 美女诱惑一区| 久久免费的精品国产v∧| 蜜桃av一区二区| 亚洲免费高清视频| 久久爱另类一区二区小说| 欧美激情成人在线| 国产日韩在线不卡| 亚洲久久一区二区| 久久久99精品免费观看不卡| 亚洲精品视频免费在线观看| 久久成人免费网| 欧美日本国产在线| 黄色亚洲免费| 亚洲欧美另类在线观看| 久久精视频免费在线久久完整在线看| 国产自产2019最新不卡| 国产精品99久久久久久久女警| 亚洲一区二区免费| 久久久久久亚洲精品不卡4k岛国| 欧美极品色图| 亚洲精品乱码久久久久久按摩观| 久久精品一本久久99精品| 日韩一级在线| 欧美日韩一区二区国产| 在线免费观看视频一区| 久久精品夜色噜噜亚洲a∨| 亚洲欧洲日本国产| 欧美一区二区三区电影在线观看| 国产精品久久久久毛片大屁完整版| 亚洲电影天堂av| 欧美一区午夜精品| 亚洲欧美日韩天堂| 欧美日韩麻豆| 国产一区二区三区高清播放| 性久久久久久久| 一区二区三区高清| 国产精品欧美久久| 国产伦一区二区三区色一情| 亚洲亚洲精品三区日韩精品在线视频 | 亚洲一区二区不卡免费| 亚洲欧美日韩国产成人| 国产日韩在线一区| 久久精品久久99精品久久| 久久av二区| 亚洲国产精品v| 亚洲高清视频在线| 国产精品二区在线观看| 亚洲午夜精品久久久久久app| 久久国产精品免费一区| 午夜久久黄色| 黄色日韩网站视频| 亚洲视频日本| 久久九九有精品国产23| 在线日韩一区二区| 亚洲全部视频| 国产精品美女久久久久久2018| 亚洲中午字幕| 亚洲神马久久| 亚洲区中文字幕| 日韩午夜在线视频| 国产在线精品成人一区二区三区| 欧美一区二区三区日韩视频| 久久大综合网| 国产精品99久久久久久www| 亚洲婷婷综合色高清在线| 伊人狠狠色j香婷婷综合| 亚洲国产你懂的| 国产精品久久久一区二区| 美女爽到呻吟久久久久| 欧美精品一区在线| 国产精品久久久久婷婷| 老司机精品视频网站| 欧美精品在线播放| 欧美成人黑人xx视频免费观看| 欧美日韩伊人| 亚洲电影天堂av| 国产麻豆一精品一av一免费| 欧美二区乱c少妇| 国产一区二区精品久久| 亚洲激情另类| 亚洲精品国产欧美| 欧美一级在线视频| 亚洲免费网址| 欧美成人三级在线| 日韩视频免费| 欧美电影打屁股sp| 久久不见久久见免费视频1| 欧美日韩国产专区| 免费观看亚洲视频大全| 国产真实乱偷精品视频免| 亚洲人成77777在线观看网| 136国产福利精品导航网址应用| 亚洲视频在线一区| 一本不卡影院| 欧美成人69av| 免费久久99精品国产| 国产精一区二区三区| 久久精品一区蜜桃臀影院 | 亚洲激情在线| 久久影院午夜论| 午夜精品视频网站| 欧美日韩一区在线视频| 欧美激情一区二区久久久| 18成人免费观看视频| 欧美夜福利tv在线| 亚洲品质自拍| 欧美日本一区| 亚洲国内精品| 亚洲免费视频中文字幕| 欧美日韩国产在线播放| 一本色道久久综合精品竹菊| 亚洲精品裸体| 欧美日韩日韩| 中文日韩在线视频| 老牛嫩草一区二区三区日本| 亚洲区一区二| 亚洲少妇自拍| 国产女人18毛片水18精品| 亚洲午夜精品一区二区| 久久九九国产精品怡红院| 国产日韩亚洲欧美精品| 999亚洲国产精| 久久精品免费电影| 国产在线拍揄自揄视频不卡99| 免费一级欧美在线大片| 欧美激情视频给我| 亚洲一区二区三区三| 国产精品乱码一区二三区小蝌蚪| 中文亚洲欧美| 欧美激情一区二区久久久| 一本一本久久a久久精品牛牛影视| 国产精品视频男人的天堂| 欧美一区二区三区在线免费观看| 日韩视频―中文字幕| 欧美性猛交99久久久久99按摩| 一区二区冒白浆视频| 精品成人在线视频| 欧美国产日本在线| 午夜日韩在线| 欧美成人一品| 欧美专区在线观看| 在线免费观看日本一区| 欧美日产一区二区三区在线观看| 欧美在线免费播放| 亚洲激情女人| 麻豆精品91| 亚洲永久视频| 亚洲精品视频在线播放| 国产精品美女视频网站| 亚洲专区在线视频| 夜夜夜精品看看| 久久综合九色| 久久久精品999| 99精品视频免费观看视频| 亚洲成在线观看| 国产精品尤物| 久久精品视频在线看| 性欧美1819性猛交| 亚洲另类在线一区|