[an error occurred while processing this directive]
Прогнал я, что немного ниже не взглянул. Вот алгоритм:
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

миниатюрный аудио-видеорекордер mAVR

Отправлено Дятковский Степан 22 апреля 2006 г. 18:56
В ответ на: Напоминает волновой алгоритм поиска пути... отправлено <font color=gray>Дятковский Степан</font> 22 апреля 2006 г. 18:37

Чтобы найти кратчайший путь програмно и без рекурсий надо сделать два волновых фронта.
0. Изначально в первый фронт помещаешь исходное положение.
1. Перебираешь все вершины рассматриваемого фронта:
1.1. В противоположный заносишь все те, в которые ты попадаешь из данной вершины (далее "достигнутые" вершины), причем записываешь в них информацию о данной (говоришь, откуда ты в них пришел).
1.2. Расстояение от источника до каждой достигнутой вершины вычисляется по формуле:
[расстояние от источника до данной вершины]+[расстояние от данной до достигнутой вершины].
1.3. Если достигнутая вершина "достигалась ранее", то обновляешь данные только в том случае, если расчитанное расстояние получилось короче того, что хранится. Также если новое расстояние для вершины не оптимально - не включаешь ее в новый волновой фронт.
2. Переключешь фронты: рассматриваемый фронт онуляешь (именно сам фронт, служебную информацию для каждой вершины нельзя удалять). Рассматриваемым делаешь толькочто заполнившийся фронт. Повторяешь действия 1-2 до тех пор пока рассматривемый фронт не пуст.
3. Обращаешься к вершине, в которую хотелось прийти. Если в ней нет данных о вершине из которой дошла "волна", то эта вершина не достижима. Если данные есть - то можно выстроить цепочку переходов - это и будет кратчайший маршрут.
вот.

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 
NoIX ключ Запомнить

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Rambler's Top100 Рейтинг@Mail.ru
Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание

E-mail: info@telesys.ru