НОД под длинную арифметику |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
НОД под длинную арифметику |
Witaliy |
Сообщение
#1
|
Новичок Группа: Пользователи Сообщений: 43 Пол: Мужской Реальное имя: Witaliy Репутация: 0 |
Здравствуйте
Мне нужно алгоритм нахождения НОД под длинную арифметику, тоисть что-бы был как можно быстрее. У меня есть рекурсивный и с использованием mod, но под длинную арифметику ето неефективно. Мне любой кроме остатка от деляния и рекурсии. Мне реализации самой длинной арифметики ненадо, только алгоритм НОД. Спасибо. Сообщение отредактировано: Witaliy - |
volvo |
Сообщение
#2
|
Гость |
А в твоей программе сразу же видно, где теряется производительность: вместо того, чтобы копировать огромные массивы данных в стек при вызове div_mod (это касается всех функций, но наиболее часто у тебя вызывается именно div_mod), просто передай константную ссылку:
procedure div_mod(const a,b : long;var rest: long); { <--- вот так }, тогда данные будут неизменны, но копироваться постоянно весь массив из 2551 элемента не будет, в процедуру будет передаваться только 4-х байтовый адрес массива... Представляешь, насколько это быстрее? Добавлено через 2 мин. P.S. Цитата Мжете показать реализация длинной арифметики? Могу, но это на FPC, если тебя устраивает этот язык - покажу... На Турбо-Паскале работать не будет... |
Текстовая версия | 4.05.2024 8:07 |