Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Прочее";
Текущий архив: 2007.01.21;
Скачать: [xml.tar.bz2];

Вниз

Как определить связен ли граф?   Найти похожие ветки 

 
Derww   (2006-12-30 12:09) [0]

Оцените, пожалуйста, мой вариант, основанный на поиске в глубину:

/////////////////////////////////////////////////////////////////////////////////
type int=longint;

Procedure solve(v: int);
var  j: int;
begin
    use[v]:=true;
    for j:=1 to n do
      if not use[j] and (a[v,j]<>0) then
        begin
        a[v,j]:=0;
        solve(j);
        end;
end;

begin
    count:=0;
    FillChar(use,sizeof(use),false);
    for i:=1 to n do if not use[i] then
      begin
       inc(count);
       solve(i);
      end;
    if count=1 then writeln("Связный") else writeln("Не связный");
end.
/////////////////////////////////////////////////////////////////////////////////

Пожалуйста, подскажите правильный ли алгоритм я использую!
Заранее благодарен!


 
TUser ©   (2006-12-30 14:23) [1]


>     FillChar(use,sizeof(use),false);

var use: packed array ...

FillChar(@use[0],length(use)*sizeof(use[0]),false);

В остальном, все вроде праильно. Только я обычно пишу совсем не так, но это дело вкуса. В частности, считать число связных компонент совсем не обязательно - можно останавливать алгоритм после того, как count стал больше 1. Поэтому вместо count можно ввести булевую переменную. Мой пример

procedure Proceed (I: integer);
vart j: integer;
begin
 use[i] := true;
 for j := 0 to high (use) do
   if i <> j then
   if a[i, j] <> 0 then
     if not use[j] then
       proceed (j);
end;    

begin
if length (use) = 0 then
 writeln ("Empty graph");
 exit;

proceed (0);
for i := 1 to high(use) do
 if not use [i] then
   writeln ("Несвязный")
   exit;
writeln ("свзный");
end.



Страницы: 1 вся ветка

Форум: "Прочее";
Текущий архив: 2007.01.21;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.043 c
1-1164375281
DelphiLexx
2006-11-24 16:34
2007.01.21
DBGridEh и OnEditButtonClick


2-1167834212
tio
2007-01-03 17:23
2007.01.21
MDI


15-1167233690
StriderMan
2006-12-27 18:34
2007.01.21
Женские духи


15-1167164837
kroner
2006-12-26 23:27
2007.01.21
Регулярные выражения в delphi


1-1164733553
Piter_Sid
2006-11-28 20:05
2007.01.21
StringGrid





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский