Данный онлайн калькулятор производит разложение чисел (факторизация) методом Ферма. Для разложении числа на множители методом Ферма, введите в калькулятор факторизируемое число, количество шагов и нажмите на кнопку "Решить". Подробнее о методе разложения Ферма посмотрите ниже.
Метод Ферма для разложения числа на множители основывается на следующем утверждении:
Утверждение 1. (метод факторизации Ферма). Пусть n>1 нечетное число1) и пусть оно представлено в виде произведения двух натуральных множителей:
n=a·b | (1) |
1) В данной статье под словом число будем понимать натуральное (целое положительное) число.
Тогда n может быть представлен в виде разности квадратов двух чисел:
n=x2−y2, (x>y) | (2) |
Обратно. Пусть n>1 нечетное число и пусть оно представляется в виде разности двух квадратов (2). Тогда n можно представить в виде произведения двух чисел.
Доказательство. Пусть n представлен в виде (1). Произведение ab можно представить в следующем виде:
Тогда
где
(3) |
Пусть теперь n представлен в виде разности квадратов двух чисел, т.е. в виде (2). Тогда можно записать
n=x2−y2=(x+y)(x−y)=ab, |
где
a=x+y, b=x−y. | (4) |
Данное утверждение дает возможность разложить нечетное число на два множителя. Отметим, что множители могут быть как простыми, так и составными.
Для разложения числа n на множители (факторизации) методом Ферма, нужно вычислить квадратный корень от n: s1=√n. Выбрать наименьшее натуральное число больше s1:s=⌈s1⌉=⌈√n⌉. Задать k=0,1,... и вычислить x=s+k, l=x2−n и выяснить, является ли число l полным квадратом какого-то натурального числа y. Если l2=y, то остановить процедуру. Получить множители числа n: a=x+y, b=x−y. Если l не является квадратом некторого натурального числа, то увеличить k на 1: k=k+1, вычислить x=s+k, l=x2−n и повторить процедуру.
Другой делитель числа n равно b=n/a.
Покажем, что количество шагов алгоритма не превосходит величины
Имеем x=s+k. Тогда k=x−s. Учитывая, что a=x+y, получим k=x−s=a−y−s. Так как справедливо неравенство a>s>b, имеем
. |
Следовательно
. |
Отметим, что процедуру разложения можно оптимизировать. Вместо вычисления на каждом шаге квадрат x2 в выражении l=x2−n, можно вычислить в начале процедуры x0=s, , а на следующих шагах
Рассмотрим метод Ферма на конкретных примерах.
Пример 1. Разложить число n=517 на множители.
Решение. Находим наименьшее целое число s такое, что , то есть . Далее задавая k=0,1,... вычисляем l=(s+k)2−n. Если на каком то шаге l является квадратом натурального числа, то процедуру останавливаем:
При k=6 получили l=324, который является квадратом числа 18. Останавливаем процедуру и вычисляем множители a=x+y=29+18=47 и b=x−y=29−18=11. Таким образом разложение числа 517 имеет следующий вид: 517=47·11.
Ответ. 517=47·11.
Пример 2. Разложить число n=43 на множители.
Решение. Находим наименьшее целое число s такое, что , то есть . Далее задавая k=0,1,... вычисляем l=(s+k)2−n. Если на каком то шаге l является квадратом натурального числа, то процедуру останавливаем:
При k=15 получили l=441, который является квадратом числа 21. Останавливаем процедуру и вычисляем множители a=x+y=22+21=43 и b=x-y=22-21=1. Таким образом разложение числа 43 имеет следующий вид: 43=43·1. Это значит, что число 43 является простым числом.
Ответ. Число 43 простое.
Отметим, что метод Ферма эффективно работает, когда множители близки к числу s=√n.
При проверке, является ли число l полным квадратом необходимо вычислить квадратный корень из большого целого числа. Мы могли бы использовать для этого алгоритм Нютона. Но это очень медленная операция. Поэтому для повышения производительности алгоритма мы рассмотрим алгоритм вычисления целозначного квадратного корня от натурального числа.
Докажем, что приведенный алгоритм находит целое число q такое, что q2≤n<(q+1)2, т.е. q=⌊√n⌋.
Пусть x, n>0. Из неравенства следует, что
или
Тогда . Отсюда следует:
или
(5) |
Таким образом, на каждом шаге алгоритма x≥q (так как ). Третий шаг алгоритма показывает, что последваптельность значений x убывает. Покажем, что алгоритм остановится тольно при x=q.
Предположим, что это не так и что на некотором шаге y≥x алгоритм остановлен, но x≠q, т.е. x>q.
Вычислим
(6) |
Так как x>q, то x2>q2. Поскольку x целое число, то x2≥(q+1)2. Но (q+1)2>n. Следовательно x2>n. Тогда из уравнения (6) следует, что y−x<0, что противоречит нашему начальному предположению y≥x.
Пример. Найти целозначный корень числа n=129.
Решение.
Присвоим x=n=129. Вычислим
Так как y<x, то присвоим x=65. Вычисляем:
Так как y<x, то присвоим x=33. Вычисляем:
y<x. Присвоим x=18. Вычисляем:
y<x. Присвоим x=11. Вычисляем:
y=x. Останавливаем алгоритм. x=11 целозначный корень от числа 129, квадрат которого не превосходит 129.
Ответ..