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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 07.04.2011, 12:18
Gman Gman вне форума
Новичок
 
Регистрация: 25.02.2010
Сообщения: 59
Репутация: -54
По умолчанию алгоритм Флойда-Уоршелла

Здравствуйте, дайте пож. ссылочку на алгоритм Флойда-Уоршелла на Pascal или Delphi, а то в сети только на C++.
Ответить с цитированием
  #2  
Старый 07.04.2011, 12:58
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

ну так наверное не алгоритм нужен, а реализация алгоритма? ибо описание алгоритма не зависит от языка его реализации.
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #3  
Старый 07.04.2011, 13:00
Аватар для PhoeniX
PhoeniX PhoeniX вне форума
Always hardcore!
 
Регистрация: 04.03.2009
Адрес: СПб
Сообщения: 3,239
Версия Delphi: GCC/FPC/FASM
Репутация: 62149
По умолчанию

Ну ты ленивый... врать бы научился.
Раз, два, три.
__________________
Оставайтесь хорошими людьми...
VK id2634397, ds [at] phoenix [dot] dj
Ответить с цитированием
  #4  
Старый 07.04.2011, 13:36
Gman Gman вне форума
Новичок
 
Регистрация: 25.02.2010
Сообщения: 59
Репутация: -54
По умолчанию

Спасибо, я уже сам нашёл, но у меня вопрос по коду:

Код:
type
  Graph = array[1..nn,1..nn] of integer;

Procedure Floyd(var a, p: graph);
  var i,j,k: integer;
  c: graph;

begin
  //A - матрица содержащая кратчайшие пути.
  //P - матрица, сохраняющая маршруты.
  Randomize;
  for i:=1 to nn do
  for j:=1 to nn do
  c[i,j] := random(100);
  for i:=1 to nn do
  for j:=1 to nn do
  begin
    a[i,j]:=c[i,j];
    p[i,j]:=0;
  end;
  for i:=1 to nn do a[i,i]:=0;
  for k:=1 to nn do
    for i:=1 to nn do
      for j:=1 to nn do
        if (a[i,k]+a[k,j] < a) then
        begin
          a[i,j]:=a[i,k]+a[k,j];
          p[i,j]:=k;
        end;
end;
а именно в этой строке
Код:
   if (a[i,k]+a[k,j] < a) then 
сдесь сумма элементов a[i,k]+a[k,j] сравнивается с a, но а ведь тоже должен быть какой то элемент (у него не указан индекс).
Ответить с цитированием
  #5  
Старый 07.04.2011, 13:40
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Цитата:
Сообщение от Gman
если б не хотел не отвечал бы на вопрос, зачем мне отминусил.
я никому не минусил
__________________
Пишу программы за еду.
__________________

Последний раз редактировалось NumLock, 07.04.2011 в 14:26.
Ответить с цитированием
  #6  
Старый 07.04.2011, 14:21
Gman Gman вне форума
Новичок
 
Регистрация: 25.02.2010
Сообщения: 59
Репутация: -54
По умолчанию

если б не хотел не отвечал бы на вопрос, зачем мне отминусил.
Ответить с цитированием
  #7  
Старый 07.04.2011, 18:02
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

Цитата:
Сообщение от Gman
Спасибо, я уже сам нашёл, но у меня вопрос по коду:
Код:
   if (a[i,k]+a[k,j] < a) then 
здесь сумма элементов a[i,k]+a[k,j] сравнивается с a, но а ведь тоже должен быть какой то элемент (у него не указан индекс).
На сайте есть комментарий, где высказано предположение, что это а[i,j]
Ответить с цитированием
  #8  
Старый 07.04.2011, 19:02
Gman Gman вне форума
Новичок
 
Регистрация: 25.02.2010
Сообщения: 59
Репутация: -54
По умолчанию

Я пробывал так, но результатвыходит не верный
Ответить с цитированием
  #9  
Старый 07.04.2011, 19:16
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

В алгоритме написано:
Код:
W[i][j] = min(W[i][j], W[i][k] + W[k][j])
а это, по-моему, и реализует кусок:
Код:
        if (a[i,k]+a[k,j] < a[i,j]) then
        begin
          a[i,j]:=a[i,k]+a[k,j];
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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