Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 04.10.2007, 20:48
about_POOH about_POOH вне форума
Прохожий
 
Регистрация: 04.10.2007
Сообщения: 1
Репутация: 10
По умолчанию Алгоритм нахождения НОД

Драсте всем!! Мне нужно в матрице найти наибольший общий делитель. Алгоритмы нахождения НОД из двух чисел предостаточно. А вот ничего адекватного насчёт нахождения НОД нескольких чисел нету.
Помогите с алгоритмом!!! плиз...
Ответить с цитированием
  #2  
Старый 11.10.2007, 17:21
Аватар для robonuk
robonuk robonuk вне форума
Прохожий
 
Регистрация: 03.10.2007
Сообщения: 13
Репутация: 10
По умолчанию

В чём проблема??? Ищи делители для одной пары чисел, потом для второй пары и т.д.... Затем таким же путём ищешь делители от найденных
делителей...
Что-то ТИПО:
72 и 48..||..63 и 117
НоДы 6 и 9
общий НоД 3
Извиняюсь если что не так подсчитал!
А по другому никак! =(
Ответить с цитированием
  #3  
Старый 12.10.2007, 12:00
vitalik007 vitalik007 вне форума
Прохожий
 
Регистрация: 12.10.2007
Адрес: Минск
Сообщения: 30
Репутация: 10
По умолчанию

function Nod(a,b:integer):integer;
begin
while (a<>0)and(b<>0) do
if a>b then a :=a mod b else b:=b mod a;
if a=0 then result:=b else result:=a;
end;
Ответить с цитированием
  #4  
Старый 12.10.2007, 13:59
Аватар для robonuk
robonuk robonuk вне форума
Прохожий
 
Регистрация: 03.10.2007
Сообщения: 13
Репутация: 10
Подмигивание

Вот накатал на паскале нахожение нода для одномерного массива:
(Поправте если что не так)
Цитата:
program NoDs;
uses crt;
var
A : array [1..99] of integer;
i : byte;
n : byte;

function Nod(a,b:integer):integer;
begin
while (a<>0)and(b<>0) do
if a>b then a :=a mod b else b:=b mod a;
if a=0 then nod:=b else nod:=a;
end;

begin
clrscr;

write(' Vvedite koli4estvo eleventov: ');
readln(n);
for i := 1 to n do
begin
write(' Vvedite ',i,' elevent: ');
readln(A[i]);
end;
{----------------------Собственно весь код--------------}
for i := 1 to n do A[1] := nod(A[1],A[i]);
{---------------------------------------------------------}
write(' Obshij NOD: ',A[1]);

readkey;
end.

Последний раз редактировалось robonuk, 12.10.2007 в 14:13.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 03:46.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025