![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() ![]() |
![]() |
kent |
![]()
Сообщение
#1
|
![]() Пионер ![]() ![]() Группа: Пользователи Сообщений: 50 Пол: Мужской Реальное имя: Андрей Репутация: ![]() ![]() ![]() |
Всем привет!
![]() Дана задача: Описать нерекурсивную функцию NOD2(A,В) целого типа, находящую наибольший общий делитель (НОД) двух натуральных чисел A и B, используя алгоритм Евклида. С помощью этой функции найти наибольшие общие делители пар A и B, A и C, A и D, если даны числа A, B, C, D. Никогда не пользовался этим алгоритмом, подскажите в чем суть алгоритма Евклида? Сообщение отредактировано: kent - 22.08.2005 6:46 |
virt |
![]() ![]()
Сообщение
#2
|
![]() Знаток ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 419 Пол: Мужской Репутация: ![]() ![]() ![]() |
первый вариaнт
function nod(a,b : longint):longint; второй вариант function nod(a,b : longint):longint; -------------------- |
kent |
![]() ![]()
Сообщение
#3
|
![]() Пионер ![]() ![]() Группа: Пользователи Сообщений: 50 Пол: Мужской Реальное имя: Андрей Репутация: ![]() ![]() ![]() |
virt, спасибо!!!
|
Дож |
![]()
Сообщение
#4
|
![]() Бывалый ![]() ![]() ![]() Группа: Пользователи Сообщений: 179 Пол: Мужской Репутация: ![]() ![]() ![]() |
В этих вариантах могут быть кое-какие проблемы если передать отрицательные
числа. function nod(a,b : longint):longint; i будет равен -45. Что бы этого не случилось нужно делать так: function nod(a,b : longint):longint; Тогда i будет равен 15. Сообщение отредактировано: volvo - 28.08.2005 12:34 -------------------- Доброго времени суток.
:nnn: |
volvo |
![]()
Сообщение
#5
|
Гость ![]() |
Цитата(Дож @ 28.08.05 10:50) В этих вариантах могут быть кое-какие проблемы если передать отрицательные числа. ![]() Цитата(kent @ 22.08.05 6:44) Описать нерекурсивную функцию NOD2(A,В) целого типа, находящую наибольший общий делитель (НОД) двух натуральных чисел A и B, используя алгоритм Евклида. Где ты видел отрицательные натуральные числа? Они все положительны ПО ОПРЕДЕЛЕНИЮ !!! |
TarasBer |
![]()
Сообщение
#6
|
![]() Злостный любитель ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 755 Пол: Мужской Репутация: ![]() ![]() ![]() |
Объясните пожалуйста, зачем делать a := a - b * (a div b ), если есть операция mod?
И вычитать тоже очень неоптимально - возьмите 1000000000 и 1 и найдите их НОД первым алгоритмом. -------------------- |
volvo |
![]()
Сообщение
#7
|
Гость ![]() |
TarasBer, ты б еще лет через 10 зашел и попросил объяснить
![]() |
amega |
![]()
Сообщение
#8
|
![]() ? ![]() ![]() ![]() Группа: Пользователи Сообщений: 283 Пол: Мужской Репутация: ![]() ![]() ![]() |
![]() ![]() |
![]() ![]() |
![]() |
Текстовая версия | 21.06.2025 9:18 |