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

隨筆 - 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>
            亚洲美女区一区| 久久亚洲国产精品日日av夜夜| 在线亚洲成人| 亚洲激情在线观看视频免费| 亚洲专区在线| 午夜精品久久久久久久| 亚洲欧美一区二区激情| 欧美在线观看视频在线| 久久精品国产一区二区三区免费看| 久久高清国产| 欧美成人小视频| 欧美日韩理论| 国产综合自拍| 亚洲人成久久| 欧美一级成年大片在线观看| 久久嫩草精品久久久久| 91久久精品美女高潮| 亚洲六月丁香色婷婷综合久久| 亚洲欧美成人一区二区三区| 久久精品日韩一区二区三区| 欧美韩国日本一区| 国产情人节一区| 99国产精品国产精品久久| 欧美一区二区在线视频| 欧美成人午夜77777| 制服丝袜激情欧洲亚洲| 免费观看30秒视频久久| 国产精品久久久久久久久久妞妞| 在线看国产一区| 午夜精品久久久久久久蜜桃app| 久久人人97超碰精品888| 亚洲欧洲三级| 久久久久久久综合色一本| 国产精品99久久不卡二区| 久久久噜噜噜| 亚洲综合二区| 欧美体内she精视频在线观看| 国产亚洲制服色| 亚洲欧美资源在线| 最新国产精品拍自在线播放| 久久激情综合| 国产欧美日韩在线| 亚洲影视九九影院在线观看| 欧美好骚综合网| 久久精品一本久久99精品| 国产精品久久久久久超碰| 亚洲欧洲精品天堂一级| 久久这里有精品视频| 国产精品99久久久久久宅男 | 亚洲天堂久久| 欧美片第一页| 亚洲欧洲日夜超级视频| 免费成人性网站| 久久精品国产69国产精品亚洲| 国产精品嫩草99av在线| 亚洲影院免费观看| 一区二区三区精品国产| 欧美日韩成人综合在线一区二区 | 久久精品夜色噜噜亚洲a∨| 一本色道久久综合| 欧美视频日韩| 亚洲一区二区精品在线观看| 亚洲人成在线观看一区二区| 欧美国产日韩一区二区在线观看| 伊人久久噜噜噜躁狠狠躁| 久久久久久久波多野高潮日日| 午夜精品久久久久久99热软件| 国产日韩欧美一区二区三区在线观看| 欧美一区二区黄| 性久久久久久久久久久久| 国产一区二区无遮挡| 久久久久国产成人精品亚洲午夜| 欧美亚洲在线观看| 狠狠色狠狠色综合| 欧美电影免费观看| 欧美日韩国内自拍| 午夜精品久久久久久久99水蜜桃| 亚洲自拍偷拍视频| 狠狠色丁香久久婷婷综合_中| 欧美大片va欧美在线播放| 欧美国产另类| 亚洲欧美一区二区精品久久久| 亚洲免费在线播放| 在线观看日产精品| 亚洲精品一区二区三区在线观看| 国产精品久久久久久久久久久久 | 日韩午夜剧场| 亚洲手机在线| 亚洲电影网站| 99综合在线| 国产亚洲精品资源在线26u| 免费影视亚洲| 国产精品草莓在线免费观看| 久久亚洲精品欧美| 欧美日韩一区二区三区四区在线观看 | 免费观看亚洲视频大全| 一区二区成人精品| 久久国产精品久久久| 亚洲人人精品| 欧美一区视频| 亚洲视频一区在线| 久久婷婷亚洲| 亚洲欧美视频一区| 欧美福利视频一区| 久久九九精品| 国产精品户外野外| 亚洲国产成人tv| 国产专区精品视频| 亚洲自拍偷拍色片视频| 一本色道久久88综合亚洲精品ⅰ | 久久一区二区精品| 欧美日韩亚洲高清一区二区| 久久综合亚洲社区| 国产欧美一区二区三区在线看蜜臀| 亚洲激情在线观看视频免费| 国产午夜亚洲精品羞羞网站| 亚洲精品视频免费在线观看| 精品88久久久久88久久久| 亚洲欧美国产高清va在线播| 亚洲最新视频在线| 欧美成人精品一区| 久久免费偷拍视频| 韩国福利一区| 久久国产毛片| 久久亚洲影音av资源网| 国产精品影音先锋| 亚洲午夜电影网| 亚洲伊人久久综合| 欧美三级视频在线播放| 亚洲精品欧美日韩专区| 亚洲靠逼com| 欧美激情综合五月色丁香| 男女激情久久| 亚洲国产精品www| 久久久视频精品| 奶水喷射视频一区| 在线成人激情| 久久综合九色欧美综合狠狠| 久久视频在线免费观看| 狠狠做深爱婷婷久久综合一区 | 欧美裸体一区二区三区| 亚洲电影在线观看| 亚洲国产欧美在线| 欧美成人一区二区三区片免费| 欧美激情精品久久久久久| 亚洲国产高清aⅴ视频| 美国成人毛片| 亚洲精品资源美女情侣酒店| 中文欧美字幕免费| 国产精品网站在线播放| 午夜在线视频观看日韩17c| 久久偷看各类wc女厕嘘嘘偷窃| 国外成人在线| 免费亚洲一区二区| 亚洲最新视频在线| 欧美伊人久久久久久久久影院| 激情av一区| 先锋影音久久久| 玖玖综合伊人| 一本色道久久综合精品竹菊| 欧美日韩在线播放三区四区| 亚洲欧美日韩国产一区| 欧美大尺度在线观看| 亚洲免费视频在线观看| 国内免费精品永久在线视频| 欧美电影免费观看高清| 亚洲专区国产精品| 欧美激情导航| 欧美专区在线观看一区| 亚洲精品社区| 国产乱码精品| 欧美二区在线观看| 午夜精品久久久久久久久久久久| 免费久久99精品国产自| 亚洲小说欧美另类婷婷| 精品成人国产| 国产精品国产三级国产aⅴ入口| 亚欧成人精品| 亚洲人成在线观看| 91久久久在线| 国产亚洲成人一区| 欧美日本中文| 久久久人成影片一区二区三区| 一本色道久久综合| 欧美88av| 久久av免费一区| 亚洲一区二区三区欧美| 亚洲激情六月丁香| 国产综合色产| 国产欧美日韩精品一区| 欧美美女日韩| 久久综合一区| 久久高清国产| 午夜精品久久久久影视| 亚洲美女免费视频| 欧美成人午夜激情| 老司机午夜精品视频| 久久久国产一区二区三区| 亚洲欧美日韩另类精品一区二区三区| 亚洲高清网站|