|
0 / 0 / 1
Регистрация: 29.03.2022
Сообщений: 18
|
||||||||||||||||
Расширенный бинарный алгоритм Евклида11.09.2022, 22:29. Показов 7469. Ответов 2
Необходимо разработать расширенный бинарный алгоритм Евклида, то есть такой, который кроме НОД еще считает коэффициенты х и у, такие, что НОД = a*x + b*y. Например, для a = 60, b = 12, имеем: 12 = 0*60 + 1*12. Вот итеративный расширенный алгоритм Евклида:
0
|
||||||||||||||||
| 11.09.2022, 22:29 | |
|
Ответы с готовыми решениями:
2
Алгоритм Евклида Алгоритм Евклида
|
|
964 / 485 / 241
Регистрация: 02.06.2016
Сообщений: 760
|
||||||||||||
| 12.09.2022, 04:23 | ||||||||||||
Сообщение было отмечено cypher111 как решение
Решениебла-бла-бла
1. Переход GCD(2A,2B) = 2 GCD(A,B). Нужно подобрать x,y которые бы удовлетворяли уравнению:
x·(2A)+y·(2B)=g, при условии что мы знаем x' и y' удовлетворящие соотношению: x'A + y'B=g', умножаем его на 2 и сразу получаем похожее на то что ищем: x'·(2A)+y'·(2B)=2g'=g, т.е. пара x',y' является одним из искомых частных решений и при данном переходе коэффициенты можно не менять. Пример, ищем GCD(6,8). 6 и 8 оба чётные, значит запускаем GCD(3,4). Он возвращает x=-1,y=1,g=1 (как вариант). Это значит, что для 3,4 выполняется : (-1)·3+(1)·4=1=GCD(3,4), а нам нужно такоеже для 6 и 8. Так вот эти x и y подойдут для 6 и 8: (-1)·6+(1)·8=2=GCD(6,8) 2. Переход GCD(2A,B) = GCD(A,B) где B - нечётное. Опять же, нужно найти x,y которые: x·(2A)+y·B=g, а мы знаем x' и y' которые: x'·A + y'·B=g 2.1 если x' делится нацело на два, то можно сделать так: (x'/2)·(2A) + y'·B=g, видим, что x=x'/2 и y=y' удовлетворяют нашему уранению для x и y 2.2 если x' нечётный, то к последнему уравнению добавим и вычтем A·B: x'·A - A·B + y'·B + A·B = g, группируем: (x'-B)·A + (y'+A)·B = g, но т.к. x' и B нечётные, то (x'-B) чётное, делаем так: (x'-B)/2·(2A) + (y'+A)·B = g. Отсюда x=(x'-B)/2, y=y'+A - искомые x,y 3. Еще есть такой переход GCD(A,B) = GCD(A-B,B), тоже не сложно вывести. Но, чтобы из рекусивного алгоритма сделать итеративный с константной памятью, нужно еще для этой последовательности (xi,yi) обратные формулы выписать. Ну и фишка алгоритма в том, что он использует не медленные умножение и деление, а быстрые битовые операции (>>1 вместо //2), на питоне они, возможно, с одинаковой скоростью выполняются - я не знаю.. рекурсивный алгоритм (ест память)
итеративный алгоритм с некоторыми оптимизациями
2
|
||||||||||||
|
0 / 0 / 1
Регистрация: 29.03.2022
Сообщений: 18
|
|
| 12.09.2022, 09:28 [ТС] | |
|
Вот оно, оказывается, как глубоко уходит в теории. Большое спасибо, буду разбираться
0
|
|
| 12.09.2022, 09:28 | |
|
Помогаю со студенческими работами здесь
3
Цикл с предусловием. Алгоритм Евклида
Найти наименьшее общее кратное этих чисел, используя функцию реализующая алгоритм Евклида
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
|
Оттенки серого
Argus19 18.03.2026
Оттенки серого
Нашёл в интернете 3 прекрасных модуля:
Модуль класса открытия диалога открытия/ сохранения файла на Win32 API;
Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
|
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога
Финальные проекты на Си и на C++:
finish-rectangles-sdl3-c. zip
finish-rectangles-sdl3-cpp. zip
|
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие.
Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
|
|
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ВВЕДЕНИЕ
Выполняя задание на управление насосной группой заполнения резервуара,. . .
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|