Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  18:53[Войти] | [Зарегистрироваться]
Ответ на вопрос № 56734

07-11-2007 00:16
Здравствуйте. У меня есть карта дорог, представленная, примерно, из 1500 узлов (все пересечения обозначены, висячих или изолированных узлов нет). Она является взвешенным неориентированным графом. Требуется найти все возможные схемы пути из заданного  пункта А в пункт В. Не получается написать алгоритм поиска и способ хранения результатов. Пыталась взять за основу какой-нибудь алгоритм из теории графов, не вышло, скорее всего, остается только вариант полного перебора, но как его организовать? Может, кто сталкивался с подобной задачей, подскажите метод или идею решения.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

11-12-2007 11:17
По-моему, это задача коммивояжера. »вопрос КС №35472« »вопрос КС №35485« »вопрос КС №42225« »вопрос КС №50571«

07-11-2007 22:50
Всем спасибо за ответы. MBo, ваш псевдокод очень помог, с остальными деталями уже справлюсь.

07-11-2007 10:37
Думаю легче всего будет работаться если весь граф уложить в матрицу смежности(будут очевидны перемещения между узлами) и выдавать результат в виде списка смежных вершин.

07-11-2007 07:41
вот пример рекурсивной реализации для небольшого числа вершин (до 32)
забит граф в виде шестиугольника с большим циклом 013652, и вершина 4 соединена с 0,3,5

procedure TForm1.Button1Click(Sender: TObject);
var
  Adj: array of array of Byte;
  Src, Dest: Integer;

  procedure FindRoute(V: Integer; Used: Integer; Route: string);
  var
    i, W: Integer;
  begin
    if V = Dest then
      Memo1.Lines.Add(Route)
    else
      for i := 0 to High(Adj[V]) do begin
        W := Adj[V, i];
        if (Used and (1 shl W)) = 0 then
          FindRoute(W, Used or (1 shl W), Route + IntToStr(W) + ' ');
      end;
  end;

begin
  SetLength(Adj, 7);
  SetLength(Adj[0], 3);
  SetLength(Adj[1], 2);
  SetLength(Adj[2], 2);
  SetLength(Adj[3], 3);
  SetLength(Adj[4], 3);
  SetLength(Adj[5], 3);
  SetLength(Adj[6], 2);
  Adj[0, 0] := 1;
  Adj[1, 0] := 0;
  Adj[0, 1] := 2;
  Adj[2, 0] := 0;
  Adj[0, 2] := 4;
  Adj[4, 0] := 0;
  Adj[1, 1] := 3;
  Adj[3, 0] := 1;
  Adj[2, 1] := 5;
  Adj[5, 0] := 2;
  Adj[3, 1] := 4;
  Adj[4, 1] := 3;
  Adj[3, 2] := 6;
  Adj[6, 0] := 3;
  Adj[4, 2] := 5;
  Adj[5, 1] := 4;
  Adj[5, 2] := 6;
  Adj[6, 1] := 5;
  Src := 0;
  Dest := 3;
  FindRoute(Src, 1 shl Src, IntToStr(Src) + ' ');
end;

выдача
0 1 3
0 2 5 4 3
0 2 5 6 3
0 4 3
0 4 5 6 3


07-11-2007 06:38
Как я понял, граф ненасыщенный (E << V^2)
Тогда можно использовать представление графа в виде списков смежности, а все пути можно получить, например, так (псевдокод):

VertexUsed: array[N] of Boolean;// инициализируется False
Route: список или строка

procedure FindRoute(V: Vertex)
if V =  Destination then
  Print(Route)
else
  для всех смежных с V вершин (W)
    if not VertexUsed[W] then begin
        VertexUsed[W] = True
        добавить W к Route
        FindRoute(W)
        VertexUsed[W] = False
        исключить W из Route
      end
 


       
 

07-11-2007 04:17
Уважаемый MBo, благодарю вас за ответ, но результат от поиска кратчайшего пути, не есть решение моей задачи. В моем примере, не  много замкнутых  траекторий, в виду чего, количество маршрутов не стремится к бесконечности, а все-таки является конечным числом.
Суть задачи – предоставить пользователю несколько возможных путей проезда, а он уже, в зависимости от своих, только ему ведомых, критериев, выберет нужный.

07-11-2007 00:52
Количество всех путей будет неимоверное - экспоненциальная зависимость от размера графа
Так что нужно определить критерии отбора маршрутов - логично, например, искать кратчайшие пути:
http://algolist.ru/maths/graphs/shortpath/

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Вода мокрая или сухая?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования