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

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

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 220451
  • 排名 - 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://www.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>
            午夜精品影院在线观看| 国产亚洲精品久久久久久| 一区二区三区欧美日韩| 亚洲精品免费看| 亚洲激情中文1区| 99精品国产在热久久| 亚洲视频大全| 久久精品官网| 农村妇女精品| 欧美午夜不卡视频| 国产精品一区二区三区乱码| 国产精品亚洲综合一区在线观看| 国产视频一区在线| 亚洲国产精品久久久久| 一区二区三区不卡视频在线观看 | 国产一区二区三区在线观看视频| 一区免费在线| 99日韩精品| 久久久噜噜噜久噜久久| 国产精品99久久99久久久二8 | 欧美一区二区三区免费视频| 国产精品乱码一区二区三区| 久久精品30| 国产在线乱码一区二区三区| 久久久91精品国产一区二区三区| 久久se精品一区精品二区| 国产视频亚洲精品| 美女在线一区二区| 男同欧美伦乱| 亚洲午夜视频在线| 亚洲欧美日韩直播| 伊人激情综合| 亚洲精品一区中文| 国产精品免费视频观看| 久久嫩草精品久久久精品| 另类天堂视频在线观看| 在线亚洲一区| 国产亚洲欧美色| 性欧美暴力猛交69hd| 一区二区三区欧美| 国产日韩欧美另类| 老鸭窝亚洲一区二区三区| 免费高清在线视频一区·| 一区二区三区日韩精品| 亚洲一卡久久| 国产精品99久久不卡二区| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 国产亚洲aⅴaaaaaa毛片| 久久综合999| 欧美日韩精品福利| 久久久久九九九| 欧美理论电影在线播放| 久久国产精品网站| 欧美日韩国产专区| 欧美xxxx在线观看| 国产伦精品一区二区三区在线观看| 老司机午夜精品视频在线观看| 欧美激情综合五月色丁香| 欧美在线视频网站| 欧美日韩成人在线播放| 美女图片一区二区| 国产婷婷色一区二区三区四区| 亚洲电影免费在线观看| 国产日本欧洲亚洲| 一区二区三区波多野结衣在线观看| 亚洲欧美日韩一区在线观看| 亚洲国产第一| 午夜在线一区二区| 亚洲一区二区三区在线视频| 女仆av观看一区| 另类亚洲自拍| 国产久一道中文一区| 日韩视频免费在线| 亚洲精品视频在线观看免费| 久久久久久一区二区三区| 午夜精品影院在线观看| 欧美日韩在线三区| 最新成人av网站| 亚洲激情视频网| 久久一二三国产| 噜噜爱69成人精品| 韩国av一区二区三区| 亚洲欧美在线aaa| 亚洲自拍偷拍麻豆| 欧美系列一区| 一二三区精品福利视频| 一区二区三区免费在线观看| 欧美国产精品| 亚洲国产精品久久久久秋霞影院| 黄色av成人| 久久精品伊人| 女主播福利一区| 在线播放中文字幕一区| 久久中文字幕一区| 欧美国产激情二区三区| 91久久久久久久久久久久久| 乱中年女人伦av一区二区| 免费成人高清| 亚洲国产午夜| 欧美精品日韩综合在线| 日韩小视频在线观看专区| 亚洲视频在线二区| 国产精品午夜久久| 欧美伊人影院| 免费观看日韩| 99www免费人成精品| 最新成人在线| 99re6热在线精品视频播放速度| 欧美1区2区3区| 日韩视频第一页| 久久福利毛片| 亚洲第一黄色网| 欧美激情网站在线观看| 中文精品视频| 久久久在线视频| 亚洲精品一区二区三区樱花 | 亚洲最快最全在线视频| 欧美日韩一区在线观看| 午夜日韩福利| 欧美黑人国产人伦爽爽爽| 亚洲视频日本| 激情综合电影网| 免费人成网站在线观看欧美高清| 亚洲日本欧美| 久久精品日韩欧美| 日韩网站在线| 国产色视频一区| 欧美精品一区二区高清在线观看| 一区二区三区av| 欧美成人免费全部| 亚洲自拍高清| 亚洲日本视频| 国产亚洲一区二区精品| 欧美激情一区二区三区四区| 午夜精品区一区二区三| 亚洲国产日韩在线| 久久精品99无色码中文字幕| 亚洲看片一区| 影音先锋日韩有码| 国产精品美女久久| 欧美高清一区二区| 久久精品亚洲精品| 中文日韩欧美| 亚洲人成网站精品片在线观看 | 久久久91精品| 亚洲一区二区三区在线看| 亚洲第一久久影院| 欧美中文在线免费| 亚洲一区二区三区在线| 亚洲精品小视频| 亚洲国产岛国毛片在线| 韩国福利一区| 国产精品一区视频网站| 欧美日韩在线精品| 欧美国产精品劲爆| 久久久久久久激情视频| 性做久久久久久免费观看欧美| av不卡在线| 亚洲精品视频啊美女在线直播| 麻豆国产精品777777在线| 欧美一级淫片播放口| 亚洲一区二区精品| 一本色道久久综合一区| 91久久精品日日躁夜夜躁欧美| 好吊视频一区二区三区四区| 国产精品一区免费视频| 国产精品久久网站| 欧美特黄一级| 亚洲午夜视频在线| 久久青草久久| 午夜精品亚洲| 亚洲欧美日韩国产综合| 一区二区三区视频观看| 亚洲黑丝一区二区| 亚洲高清免费| 伊人精品视频| 在线视频国产日韩| 在线免费观看视频一区| 一区二区三区自拍| 韩国一区二区在线观看| 国产综合色在线| 激情综合色综合久久| 激情欧美国产欧美| 亚洲国产99| 亚洲福利国产精品| 亚洲精品一区二区三区四区高清| 亚洲巨乳在线| 亚洲欧洲99久久| 久久精品久久99精品久久| 麻豆成人在线播放| 亚洲国产精品黑人久久久| 亚洲尤物视频网| 夜夜嗨av一区二区三区四季av | 亚洲午夜久久久| 亚洲男人的天堂在线观看| 欧美一区二区高清| 久久久久久久久久久一区| 欧美成人午夜77777| 亚洲精品国产精品乱码不99按摩 | 午夜精品久久久久久久久 |