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

隨筆 - 87  文章 - 279  trackbacks - 0
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 220431
  • 排名 - 118

最新評論

閱讀排行榜

評論排行榜

歐拉函數一般形式:
當 n 為素數時: phi(n) = n-1
當 n 為合數時: phi(n) = n∏(1-1/p) 其中(p為n的素數因子)

題目pku1091,要求我們求 x1..xn,m這樣的序列的個數,其中xi(1<=i<=n), 使 gcd(x1, ..,xn,m)=1;
我們按歐拉函數的形式猜想如下方程:
當 n 為素數時: phi(m,n) = m^n-1
當 n 為合數時: phi(m,n) = m^n∏(1-1/p^n) 其中(p為n的素數因子)

不給出嚴格數學證明(不會-_-),上兩式具體含義:
當 n為素數 phi(m,n) = m^n-1 顯然成立
當 n 為合數時 可以假象有一個m進制n位的數,然后其中一位有m的約數p的概率為1/p, 則n位同時有p的約數的概率就為(1-1/p^n), 運用乘法原理,可以得式 phi(m,n) = m^n∏(1-1/p^n)
 
code:

#include <iostream>
using namespace std;

typedef __int64 llong;
const llong MAXN = 110000;
llong tf[MAXN], su[MAXN], ns, num[MAXN], nn;

void  init() {
    llong i, j;
    
for (i=2; i<MAXN; i++) {
        
if (!tf[i]) {
            su[ns
++]=i;
            
for (j=i*i; j<MAXN; j+=i) tf[j]=1;
        }
    }
}

llong ppow(llong a, llong b) {
    llong ret
=a;
    llong i;
    
for (i=1; i<b; i++) ret *= a;
    return ret;
}

int main() {
    llong n, m, i, p;
    llong ans
=0;
    init();
    
while (scanf("%I64d%I64d"&n, &m)!=EOF) {
        p
=m; nn=0; ans=0;
        
for (i=0; i<ns; i++) {
            
if (p%su[i]==0) {
                
while (p%su[i]==0) p/=su[i];
                num[nn
++]=su[i];
            }
            
if (p==1) break;
        }
        
if (!nn) {
            ans 
= ppow(m,n)-1;
        } 
else {
            ans 
= ppow(m,n);
            
for (i=0; i<nn; i++) {
                ans 
= ans/ppow(num[i],n)*(ppow(num[i],n)-1);
            }
        }
        printf(
"%I64d\n", ans);
    }
    return 
0;
}
posted @ 2007-09-02 22:57 豪 閱讀(2518) | 評論 (4)編輯 收藏

(1)定理:設x0,x1,x2,...是無窮實數列,xj>0,j>=1,那么,
      (i)對任意的整數 n>= 1, r>=1有
            <X0,...,Xn-1,Xn,...,Xn+r> = <X0,...,Xn-1,<Xn,...,Xn+r>> 
            =   <X0,...,Xn-1,Xn+1/<Xn+1,...,Xn+r>>.
      特別地有
            <X0,...,Xn-1,Xn,Xn+1> = <X0,...,Xn-1,Xn+1/Xn+1>
      注:用該定理可以求連分數的值

(2)對于連分數數數列 <X0,...Xn> 有遞推關系:
      Pn = XnPn-1+Pn-2;
      Qn = XnQn-1+Qn-2;
      定義:  P-2 = 0; P-1 = 1; Q-2 = 1; Q-1 = 0;
      所以:  P0 = X0; Q0 = 1; P1 = X1X0+1; Q1 = X1;
      特別地:當 Xi=1 時, {Pn}, {Qn}為Fbi數列


(3)pell方程: x^2+ny^2=+-1的解法:
      若n是平方數,則無解, 否則:
      先求出sqrt(n)的連分數序列<x0,x1..xn> 其中xn = 2*x0;
      對于 x^2+ny^2=-1
      若n為奇數,則 x=Pn-1, y=Qn-1; n為偶數時無解
      對于 x^2+ny^2=1
      若n為偶數,則 x=Pn-1, y=Qn-1; n為奇數時x=P2n-1, y=Q2n-1
      注:以上說的解均為最小正解
      
      
      
      

posted @ 2007-08-28 14:59 豪 閱讀(1334) | 評論 (2)編輯 收藏

問題簡單來說就是 a = ai (mod ni)   求未知數a,
 以下小結略去證明, 只是對定理作了必要的解釋, 要了解相關定理,可查閱數論資料.

中國余數定理:
      設 n=n1*n2...nk, 其中因子兩兩互質.有:  a-----(a1,a2,...,ak), 其中ai = a mod ni, 則 a和(a1,a2,...,ak)關系是一一對應的.就是說可以由 a求出(a1,a2,...,ak), 也可以由(a1,a2,...,ak)求出a

推論1:
      對于 a=ai  (mod ni) 的同余方程,有唯一解

下面說說由(a1, a2, ..., ak)求a的方法:
定義 mi = n1*n2*...nk / ni;   ci = mi(mf  mod ni);   其中 mi*mf  mod ni = 1;
         則 a = (a1*c1+a2*c2+...+ak*ck)      (mod n)      (注:由此等式可求a%n, 當n很大時)

中國剩余定理關鍵是mf的求法,如果理解了擴展歐幾里得 ax+by=d, 就可以想到:
                     mi*mf  mod ni = 1 => mi*mf+ni*y=1;

代碼如下:

 

#include <iostream>
#include 
<cmath>
using namespace std;

const int MAXN = 100;
int nn, a[MAXN], n[MAXN];

int egcd(int a, int b, int &x, int &y) {
    
int d;
    
if (b == 0) {
        x 
= 1; y = 0;
        return a;
    } 
else {
        d 
= egcd(b, a%b, y, x);
        y 
-= a/b*x;
        return d;
    }
}

int lmes() {
    
int i, tm=1, mf, y, ret=0, m;
    
for (i=0; i<nn; i++) tm *= n[i];
    
for (i=0; i<nn; i++) {
        m 
= tm/n[i];
        egcd(m, n[i], mf, y);
        ret 
+= (a[i]*m*(mf%n[i]))%tm;
    }
    return (ret
+tm)%tm;
}

int main() {
    a[
0= 4; a[1= 5;
    n[
0= 5; n[1= 11;
    nn 
= 2;
    printf(
"%d\n", lmes());
    return 
0;
}


 

posted @ 2007-08-27 16:46 豪 閱讀(11673) | 評論 (2)編輯 收藏

對于擴展歐幾里得主要部分說明:
1. d' = bx'+(a mod b)y', d' = gcd(b, a mod b);
    設 d = gcd(a, b), 因為 d = d', 所以
    d = d' = bx'+(a mod b)y' = bx' + (a-floor(a/b)*b)y' = ay'+b(x'-floor(a/b)y');
    故有迭代:
    x = y'; y = x'-floor(a/b)y';

對于解方程主要部分說明:
1.首先給出兩個定理(證明請查看相關數論書):
   A. 方程 ax = b (mod n) 有解, 當且僅當 gcd(a, n) | b;
   B. 方程 ax = b (mod n) 有d個不同的解, 其中 d = gcd(a, n);
2.證明方程有一解是: x0 = x'(b/d) mod n;
   由 a*x0 = a*x'(b/d) (mod n)
         a*x0 = d (b/d) (mod n)   (由于 ax' = d (mod n))
                 = b (mod n)
   證明方程有d個解: xi = x0 + i*(n/d)  (mod n);
   由 a*xi (mod n) = a * (x0 + i*(n/d)) (mod n)
                             = (a*x0+a*i*(n/d)) (mod n)
                             = a * x0 (mod n)             (由于 d | a)
                             = b

代碼如下:

#include <iostream>
#include 
<cmath>
using namespace std;

int egcd(int a, int b, int &x, int &y) {
    
if (b == 0) {
        x 
= 1; y = 0;
        return a;
    } 
else {
        
int tx, ty, d;
        d 
= egcd(b, a%b, tx, ty);
        x 
= ty; y = tx-a/b*ty;
        return d;
    }
}

void mels(
int a, int b, int n) {
    
int tx, ty, d, x0, i;
    d 
= egcd(a, n, tx, ty);
    
if (b%d==0) {
        x0 
= ((tx*b/d)%n+n)%n;
        
for (i=0; i<d; i++) {
            printf(
"%d ", (x0+i*n/d)%n);
        }
    } 
else {
        printf(
"No solutions!");
    }
    printf(
"\n");
}

int main() {
    mels(
1430100);
    return 
0;
}
posted @ 2007-08-27 11:14 豪 閱讀(2203) | 評論 (2)編輯 收藏
    好久沒寫了,主要是不知道寫什么,發個剛寫好的比較通用的堆吧,sigh~

    http://m.shnenglu.com/qywyh/articles/28653.html
posted @ 2007-07-23 21:04 豪 閱讀(396) | 評論 (0)編輯 收藏
僅列出標題
共18頁: 1 2 3 4 5 6 7 8 9 Last 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品系列在线| 亚洲先锋成人| 欧美精品日韩一本| 国产欧美丝祙| 欧美成ee人免费视频| 99re热精品| 国产精品99久久99久久久二8 | 欧美一区二区大片| 欧美日韩大片| 亚洲成色www8888| 久久视频在线看| 亚洲综合精品| 国产视频一区二区在线观看 | 亚洲经典三级| 亚洲一区免费在线观看| 欧美三区在线视频| 一本色道久久综合狠狠躁篇怎么玩| 久久精品综合网| 一本色道久久综合狠狠躁篇的优点| 欧美日韩久久不卡| 一区二区欧美日韩| 国产精品啊v在线| 亚洲欧美精品伊人久久| 亚洲欧洲日本专区| 久久精品一区二区三区四区| 国产伦精品一区| 久久免费黄色| 久久国产福利国产秒拍| 精品福利免费观看| 亚洲高清视频在线| 欧美日韩精品一区二区在线播放 | 欧美一区永久视频免费观看| 一区二区三区免费网站| 国产美女一区| 久久国产福利| 久久婷婷av| 日韩网站在线看片你懂的| 最新国产成人在线观看| 欧美日韩三级一区二区| 日韩网站在线| 亚洲一区二区日本| 欧美中文字幕第一页| 亚洲欧美日韩精品综合在线观看 | 久久精品视频在线免费观看| 亚洲欧美一区二区原创| 欧美一区二区三区免费观看视频 | 欧美一级大片在线免费观看| 欧美午夜在线一二页| 亚洲欧美日韩在线一区| 香蕉成人久久| 99视频精品在线| 午夜精品剧场| 亚洲国产一区在线| 夜夜狂射影院欧美极品| 狠狠色丁香久久婷婷综合丁香| 亚洲国产精品精华液网站| 欧美性猛交xxxx乱大交蜜桃 | 欧美精选在线| 久久精品综合| 另类专区欧美制服同性| 亚洲国产精品一区二区www| 欧美激情一区二区三区蜜桃视频 | 亚洲综合国产激情另类一区| 欧美日韩在线免费| 亚洲自拍电影| 在线免费观看一区二区三区| 欧美国产91| 国产综合色在线| 国产精品成人一区二区网站软件| 久久九九99| 欧美成人激情视频| 亚洲人线精品午夜| 久久精品国产99国产精品澳门| 一区二区久久久久久| 久久久亚洲高清| 欧美在线视频播放| 久久国产欧美| 1000部国产精品成人观看| 亚洲视频一区二区免费在线观看| 精品99一区二区三区| 久久久爽爽爽美女图片| 国内自拍一区| 欧美精品一区在线| 午夜精品福利视频| 久久综合伊人77777蜜臀| 亚洲精品乱码| 欧美日本在线视频| 久久久久久久久蜜桃| 你懂的国产精品| 亚洲高清在线观看一区| 欧美国产日韩免费| 久久天天躁狠狠躁夜夜av| 国产精品日韩电影| 亚洲一级在线观看| 亚洲欧美日韩中文播放| 欧美性感一类影片在线播放 | 久久精品99无色码中文字幕| 国产精品二区影院| 一区二区三区日韩| 新狼窝色av性久久久久久| 国产精品一区二区三区免费观看| 这里只有精品在线播放| 性欧美18~19sex高清播放| 国产日产亚洲精品| 久久久精品国产免大香伊| 亚洲看片网站| 久久亚洲综合网| 欧美黄污视频| 99精品欧美一区| 欧美三级电影网| 这里只有精品视频| 久久久欧美一区二区| 亚洲高清在线| 国产精品v欧美精品v日本精品动漫 | 亚洲免费久久| 国产精品videossex久久发布| 亚洲欧美日韩精品| 久久亚洲影音av资源网| 亚洲国产精品尤物yw在线观看| 欧美a级在线| 一本色道久久综合亚洲精品不卡 | 亚洲国产欧美一区| 欧美国产日韩一二三区| 国产欧美激情| 亚洲欧美制服另类日韩| 国产亚洲电影| 欧美国产高清| 亚洲小说欧美另类婷婷| 久久午夜精品| 一区二区三区视频免费在线观看| 欧美视频一区在线观看| 久久成人免费电影| 亚洲精品永久免费| 久久免费视频观看| 亚洲国产精品t66y| 亚洲在线观看视频网站| 牛牛影视久久网| 黑人巨大精品欧美黑白配亚洲| 中日韩美女免费视频网站在线观看| 久久九九国产| 欧美一区二区成人| 国产精品一区二区黑丝| 亚洲综合色网站| 久久亚洲精选| 国产精品久久久久久久久久久久久 | 久热爱精品视频线路一| 国产精品爱久久久久久久| 久久美女性网| 亚洲一区亚洲二区| 亚洲第一久久影院| 久久激情综合网| 这里只有精品电影| 亚洲高清在线| 韩国成人精品a∨在线观看| 欧美成人一区二区三区片免费| 亚洲在线视频观看| 亚洲人午夜精品免费| 美女国内精品自产拍在线播放| 亚洲欧美日韩第一区| 99国产精品一区| 亚洲国产欧美日韩| 狠狠久久婷婷| 国产亚洲欧美日韩在线一区| 欧美色图麻豆| 欧美巨乳在线观看| 免费永久网站黄欧美| 久久九九精品| 久久黄色级2电影| 亚洲影视综合| 一区二区精品在线| 亚洲精品影视在线观看| 亚洲高清自拍| 欧美电影在线观看完整版| 久久亚洲一区二区| 久久www成人_看片免费不卡| 亚洲欧美日韩精品久久奇米色影视| 99精品国产在热久久| 日韩午夜精品视频| 日韩系列欧美系列| 久久久精品视频成人| 亚洲国产一区二区a毛片| 狠狠88综合久久久久综合网| 国产主播精品| 黑人一区二区三区四区五区| 一区二区在线观看视频在线观看| 国产一区二区三区四区三区四| 国产一区二区你懂的| 激情综合亚洲| 亚洲人成啪啪网站| 夜夜狂射影院欧美极品| 中文日韩电影网站| 亚洲一区在线免费| 欧美一区二区三区在线观看| 久久精品欧美| 欧美高清视频在线观看| 亚洲精品国产精品乱码不99按摩| 亚洲日韩成人| 亚洲一区三区视频在线观看| 欧美一区二区在线看| 美女久久网站|