ユークリッドの互除法 - Wikipedia
出典: フリー百科事典『ウィキペディア(Wikipedia)』
![](https://upload.wikimedia.org/wikipedia/commons/thumb/e/e2/Euclidean_algorithm_252_105_animation_flipped.gif/170px-Euclidean_algorithm_252_105_animation_flipped.gif)
クロスバーは、最大公約数(GCD)である21の倍数を表す。
それぞれのステップにおいて、1つの番号がゼロになるまで、より少ない数はより大きな数から引かれる。
残りの数は、GCD。
ユークリッドの互除法(ユークリッドのごじょほう、英: Euclidean Algorithm)は、2 つの自然数の最大公約数を求める手法の一つである。
2 つの自然数 a, b (a ≧ b) について、a の b による剰余を r とすると、 a と b との最大公約数は b と r との最大公約数に等しいという性質が成り立つ。この性質を利用して、 b を r で割った剰余、 除数 r をその剰余で割った剰余、と剰余を求める計算を逐次繰り返すと、剰余が 0 になった時の除数が a と b との最大公約数となる。
明示的に記述された最古のアルゴリズムとしても知られ、紀元前300年頃に記されたユークリッドの『原論』第 7 巻、命題 1 から 3 がそれである[注釈 1]。
(問題) 1071 と 1029 の最大公約数を求める。
- 1071 を 1029 で割った余りは 42
- 1029 を 42 で割った余りは 21
- 42 を 21 で割った余りは 0
よって、最大公約数は21である。
a, b は自然数で a ≠ 0 とする。 b を a で割った商を q、剰余を r とすると
- b = qa + r
今、d0 を a と r の両方を割り切る自然数とする。
このとき d0 は積 qa を割り切るから、和 qa + r も割り切るが、qa + r は b に等しい。したがって、d0 は a とb を割り切る。すなわち a と r の公約数はすべてb と aの公約数である。
逆に、d1 を b と a の両方を割り切る自然数とする。
d1 は qa を割り切るから差 b - qa を割り切るが、b - qa は r に等しい。したがって、d1 は a とrを割り切る。言い換えると b と a の公約数はすべてa と r の公約数である。
したがって、b と a の公約数全体の集合は a と r の公約数全体の集合に等しく、特に b と a の最大公約数は a と r の最大公約数でなければならない。
![](https://upload.wikimedia.org/wikipedia/commons/thumb/1/1a/GCM_Of_20_And_32.gif/480px-GCM_Of_20_And_32.gif)
手続き的に記述すると、次のようになる。
- 入力を m, n (m ≧ n) とする。
- n = 0 なら、 m を出力してアルゴリズムを終了する。
- m を n で割った余りを新たに n とし、更に 元のnを新たにm とし 2. に戻る。
上記の手順は「n, m に対して剰余の演算を行うことができる」という仮定だけに依っているので、整数環だけではなく任意のユークリッド整域においても同様にして最大公約因子を求めることができる。
整数 m, n の最大公約数 (英: Greatest Common Divisor) を gcd(m,n) と表すときに、(拡張された)ユークリッドの互除法を用いて、mx + ny = gcd(m, n) の解となる整数 x, y の組を見つけることができる。上の例の場合、m = 1071, n = 1029 のとき、
- 1071 = 1 × 1029 + 42
- 1029 = 24 × 42 + 21
- 42 = 2 × 21
であるから、gcd(1071, 1029) = 21 であり、
- 21 = 1029 − 24 × 42
- = 1029 − 24 × (1071 − 1 × 1029)
- = −24 × 1071 + 25 × 1029
となるので、x = −24, y = 25 である。
特に、m, n が互いに素(最大公約数が 1)である場合、mx + ny = 1 の整数解を (x, y) とすると、mx + ny = c は任意の整数 c に対して整数解 (cx, cy) をもつことが分かる。
一般に、
において、ユークリッドの互除法の各過程を繰り返して
が得られるとき、
すなわち
ここで
とおくと、
であるから
は存在して
これらの過程において、、ユークリッドの互除法により、
であるから、
を考慮すると、
となる。
とおき、ユークリッドの互除法の各過程で得られた ,
,
等を用いて、右辺を計算すれば、左辺の
,
が求まり、これはベズーの等式
を満たす[6]。
割って余りを取るという操作を最悪でも小さいほうの十進法での桁数の約 5 倍繰り返せば、最大公約数に達する(ラメの定理)。
最大公約数を求めるのに素因数分解すればよいと思うかもしれないが、この定理は(m, n が大きいときには)素因数分解をするよりもユークリッドの互除法によるほうがはるかに速いということを述べている。
実際、計算複雑性理論においては最大公約数を求めることは「容易な問題」として知られており、素因数分解は「困難な問題」であろうと考えられている。 入力された2つの整数のうち小さいほうの整数 n の桁数を d とすれば、ユークリッドの互除法では O(d) 回の除算で最大公約数が求められる。桁数 d は O(log n) なので、ユークリッドの互除法では O(log n) 回の除算で最大公約数が求められる。
上の例で出てきた、1071 と 1029 の最大公約数を求める過程は、次のように表せる。
すなわち、
したがって、
このように、 n と m (n > m) の最大公約数を求める際のユークリッドの互除法の割り算の商は、有理数 n/m の連分数展開になっている。
- ^ ユークリッド & 中村ほか 1996, p. 149.
- ^ ユークリッド & 中村ほか 1996, pp. 150f.
- ^ ユークリッド & 中村ほか 1996, p. 151.
- ^ ユークリッド & 中村ほか 1996, p. 152.
- ^ ユークリッド & 中村ほか 1996, pp. 152f.
- ^ 岩堀 1983.
- 岩堀長慶『2次行列の世界』岩波書店〈数学入門シリーズ 4〉、1983年4月22日。ISBN 4-00-007634-5。
- 岩堀長慶『2次行列の世界』岩波書店〈新装版 数学入門シリーズ〉、2015年3月6日。ISBN 978-4-00-029834-6。
- ハイベア、メンゲ 編『ユークリッド原論』中村幸四郎・寺阪英孝・伊東俊太郎・池田美恵訳・解説、共立出版。 - 全13巻の最初の邦訳。
- (ハードカバー)1971年7月。ISBN 4-320-01072-8
- (縮刷版)1996年6月。ISBN 4-320-01513-4
- (追補版)2011年5月。ISBN 978-4-320-01965-2
- ハイベア、メンゲ 編『エウクレイデス全集』 (全5巻)、東京大学出版会。 - 「エウクレイデス全集」の世界初の近代語訳。
- 第2巻 原論VII-X、斎藤憲 訳・解説、2015年8月。ISBN 978-4-13-065302-2
- 『ユークリッドの互除法の証明と不定方程式』 - 高校数学の美しい物語
- 日本大百科全書(ニッポニカ)『ユークリッドの互除法』 - コトバンク
- Weisstein, Eric W. "Euclidean Algorithm". mathworld.wolfram.com (英語).
- Hazewinkel, Michiel, ed. (2001), “Euclidean algorithm”, Encyclopedia of Mathematics, Springer, ISBN 978-1-55608-010-4