Алгоритм Евклида

Материал из Циклопедии
Перейти к: навигация, поиск
Математика. Натуральные числа: Алгоритм Евклида // Центр онлайн-обучения «Фоксфорд»
Функция от x и y, обозначающая цветом, следуя по спектру, число итераций по алгоритму Евклида. Наиболее явный синий луч — золотая пропорция

Алгоритм Евклида — издревле известный алгоритм, находящий наибольший общий делитель двух натуральных чисел, через повтор операции деления с остатком. Носит имя древнегреческого математика Евклида.

На языке Scheme:

(define (E m n)
 (cond ((= n 0) m) (else (E n (modulo m n)))))

Словами: при вводе [math]m,n: m \gt n[/math], если n ноль, ответ m,
иначе рекурсия со вводом (n и (остаток от деления m на n)).

Выглядит в развернутом виде так:
[math]m = na_0 + b_0[/math], [math]0 \lt b_0 \lt n[/math]
[math]n = b_0a_1 + b_1[/math], [math]0 \lt b_1 \lt b_0[/math]
[math]b_0 = b_1a_2 + b_2[/math], [math]0 \lt b_2 \lt b_1[/math]

[math]b_{k-3} = b_{k-2}a_{k-1} + b_{k-1}[/math], [math]0 \lt b_{k-1} \lt b_{k-2}[/math]
[math]b_{k-2} = b_{k-1}a_k[/math] (деление нацело).

Если вводится числитель и знаменатель рационального числа́, то разложение по алгоритму Евклида выдаёт чи́сла, образующие его цепную дробь:
[math]\frac{m}{n} = a_0 + \cfrac{1}{a_1 + \cfrac{1}{a_2 + \cfrac{1}{ \ddots + \cfrac{1}{a_k} }}}[/math]

Если обозначить наибольший общий делитель чисел a и b как НОД(a, b), то увидим, что в процессе алгоритма Евклида вычисляется наибольший общий делитель заданных m и n:
НОД(m, n) = НОД(n, b0) = НОД(b0, b1) = … = НОД (bk-2,bk-1) = bk-1.

Также по индукции доказывается, что на каждом шаге r выполнено br = mxr + nyr для некоторых целых xr и yr.

В частности, существует представление НОД(m, n) = mx + ny для некоторых целых x и y.

Отсюда выводится, что если натуральное число a не делится на простое число p, то существуют такие целые x и y, что ax + py = 1. Из этого следует, что если произведение двух натуральных чисел ab делится на простое число p, то хотя бы одно из них делится на p. Этот факт является ключевым при доказательстве основной теоремы арифметики о единственности разложения натуральных чисел на простые множители, которая опирается на то, что для натуральных чисел существует алгоритм Евклида. Алгебраическим языком это выражается так: в кольце целых чисел все идеалы главные, а значит оно факториальное (с единственным разложением на простые).

Персональные инструменты
Пространства имён

Варианты
Действия
Навигация
Инструменты