導航:首頁 > 源碼編譯 > 歐幾里得演算法的故事

歐幾里得演算法的故事

發布時間:2023-06-17 01:36:09

1. 歐幾里德演算法

The Euclidean Algorithm
歐幾里德演算法(又稱輾轉相除法)是一種用於快速尋找兩個整數的最大公約數的技巧。

最大公約數 Greatest Common Divisor (GCD):整數 A 和 B 的最大公約數是指能夠同時整除 A 和 B 的最大整數。

使用歐幾里德演算法尋找 GCD(A,B) 的過程如下:

歐幾里德演算法使用了下述特性:

如果 A 和 B 其中一個為 0,便可利用前兩個特性得出 GCD。 第三個特性幫助我們將大而復雜的問題化簡為小而容易解決的問題。 歐幾里德演算法先利用第三個特性迅速化簡問題,直至可以通過前兩個特性求解為止。

證明 GCD(A,0)=A 的過程如下:

GCD(0,B)=B 的證明過程與此類似,區別僅在於用 B 替換 A。

先證明較簡單的 GCD(A,B)=GCD(B,A-B),再證明 GCD(A,B)=GCD(B,R)

根據定義 GCD(A,B) 可均分 A。因此,A 一定是 GCD(A,B) 的倍數,即 X⋅GCD(A,B)=A ,此處的 X 是某個整數。 根據定義 GCD(A,B) 可均分 B。因此,B 一定是 GCD(A,B) 的倍數,即 Y⋅GCD(A,B)=B ,此處的 Y 是某個整數。

根據 A-B=C 可得出:

由此可見 GCD(A,B) 可均分 C。 上圖的左側部分展示了此證明,提取如下:

證明 GCD(B,C) 均分 A
根據定義 GCD(B,C) 可均分 B。因此,B 一定是 GCD(B,C) 的倍數,即 M⋅GCD(B,C)=B ,此處的 M 是某個整數。 根據定義 GCD(B,C) 可均分 C。因此,C 一定是 GCD(B,C) 的倍數,即 N⋅GCD(B,C)=B ,此處的 N 是某個整數。

根據 A-B=C 可得出:

B+C=A
M⋅GCD(B,C) + N⋅GCD(B,C) = A
(M + N)⋅GCD(B,C) = A
由此可見 GCD(B,C) 可均分 A。 下圖展示了此證明:

證明 GCD(A,B)=GCD(A,A-B)
根據定 GCD(A,B) 均分 B
同時,已證明 GCD(A,B) 均分 C
因此,GCD(A,B) 是 B 和 C 的公約數
由於 GCD(B,C) 是 B 和 C 的最大公約數,所以 GCD(A,B) 必須小於或等於 GCD(B,C)。

根據定義 GCD(B,C) 均分 B
同時,已證明 GCD(B,C) 均分 A
因此,GCD(B,C) 是 B 和 A 的公約數
由於 GCD(A,B) 是 A 和 B 的最大公約數,所以 GCD(B,C) 必須小於或等於 GCD(A,B)。

∵ GCD(A,B)≤GCD(B,C) 且 GCD(B,C)≤GCD(A,B) ∴ GCD(A,B)=GCD(B,C) 即 GCD(A,B)=GCD(B,A-B)

下圖的右側部分展示了此證明的圖示:

前面已證明了 GCD(A,B)=GCD(B,A-B) 另外,對於 GCD( ) 而言,括弧中各項的順序並不重要,因此 GCD(A,B)=GCD(A-B,B) 那麼,如果反復應用 GCD(A,B)=GCD(A-B,B),便可得到: GCD(A,B)=GCD(A-B,B)=GCD(A-2B,B)=GCD(A-3B,B)=...=GCD(A-Q⋅B,B) 由於 A= B⋅Q + R 可得 A-Q⋅B=R,所以 GCD(A,B)=GCD(R,B) 。 由於括弧中各項的順序並不重要,因此最終可得: GCD(A,B)=GCD(B,R)

找尋 270 和 192 的最大公約數:

A=270, B=192

A=192, B=78

A=78, B=36

A=36, B=6

A=6, B=0

從上面的過程可以看出: ∵ GCD(270,192) = GCD(192,78) = GCD(78,36) = GCD(36,6) = GCD(6,0) = 6 ∴ GCD(270,192) = 6

2. 歐幾里德演算法是什麼啊

歐幾里德演算法
歐幾里德演算法又稱輾轉相除法,用於計算兩個整數a,b的最大公約數。其計算原理依賴於下面的定理:

定理:gcd(a,b) = gcd(b,a mod b)

證明:a可以表示成a = kb + r,則r = a mod b
假設d是a,b的一個公約數,則有
d|a, d|b,而r = a - kb,因此d|r
因此d是(b,a mod b)的公約數

假設d 是(b,a mod b)的公約數,則
d | b , d |r ,但是a = kb +r
因此d也是(a,b)的公約數

因此(a,b)和(b,a mod b)的公約數是一樣的,其最大公約數也必然相等,得證。

歐幾里德演算法就是根據這個原理來做的,其演算法用C++語言描述為:

void swap(int & a, int & b)
{
int c = a;
a = b;
b = c;
}
int gcd(int a,int b)
{
if(0 == a )
{
return b;
}
if( 0 == b)
{
return a;
}
if(a > b)
{
swap(a,b);
}
int c;
for(c = a % b ; c > 0 ; c = a % b)
{
a = b;
b = c;
}
return b;
}
參考資料:internet

3. 歐幾里得演算法是什麼

歐幾里得演算法又稱輾轉相除法,是指用於計算兩個非負整數a,b的最大公約數。應用領域有數學和計算機兩個方面。計算公式gcd(a,b) = gcd(b,a mod b)。

輾轉相除法的演算法步驟為,兩個數中用較大數除以較小數,再用出現的余數除除數。

再用出現的余數(第二餘數)去除第一餘數,如此反復,直到最後余數是0為止。

輾轉相除法是利用以下性質來確定兩個正整數a和b的最大公因子的:

1、若r是a ÷ b的余數,且r不為0,則gcd(a,b) = gcd(b,r)。

⒉、a和其倍數之最大公因子為a。

另一種寫法是:

⒈、令r為a/b所得余數(0≤r),若r= 0,演算法結束;b即為答案。

⒉、互換:置a←b,b←r,並返回第一步。

閱讀全文

與歐幾里得演算法的故事相關的資料

熱點內容
dvd光碟存儲漢子演算法 瀏覽:757
蘋果郵件無法連接伺服器地址 瀏覽:963
phpffmpeg轉碼 瀏覽:672
長沙好玩的解壓項目 瀏覽:145
專屬學情分析報告是什麼app 瀏覽:564
php工程部署 瀏覽:833
android全屏透明 瀏覽:737
阿里雲伺服器已開通怎麼辦 瀏覽:803
光遇為什麼登錄時伺服器已滿 瀏覽:302
PDF分析 瀏覽:486
h3c光纖全工半全工設置命令 瀏覽:143
公司法pdf下載 瀏覽:382
linuxmarkdown 瀏覽:350
華為手機怎麼多選文件夾 瀏覽:683
如何取消命令方塊指令 瀏覽:350
風翼app為什麼進不去了 瀏覽:779
im4java壓縮圖片 瀏覽:362
數據查詢網站源碼 瀏覽:151
伊克塞爾文檔怎麼進行加密 瀏覽:893
app轉賬是什麼 瀏覽:163