Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Поиск кратчайшего пути

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
fishca
Гость





СообщениеДобавлено: Пт Фев 22 2002 10:55    Заголовок сообщения: Поиск кратчайшего пути Ответить с цитатой

Помогите с решением задачи, пожалуйста!
Надо найти кратчайший путь из одной точки в другую с обходом прпятствий на пути.
Вернуться к началу
JekLove



Зарегистрирован: 22.02.2002
Сообщения: 41
Откуда: Новосибирск

СообщениеДобавлено: Пт Фев 22 2002 21:25    Заголовок сообщения: Re: Поиск кратчайшего пути Ответить с цитатой

Рассмотрим случай, когда имеется лабиринт в виде матрицы. Алгоритм следующий. Заполняем все "дорожки" в лабиринте нулями. В начальную клетку записываем единицу. В смежные клетки,
которые являются "свободным пространством",
т.е., по которым можно ходить, пишем двойки. И так далее. Для каждой из клеток, обработанных на предыдущем шаге, повторяем процедуру: в каждую из смежных клеток, в которых стоит ноль, т.е., которые еще не обработаны, записываем номер текущего шага. Ну и на каждом шаге проверяем, является ли данная клетка конечной. Если эта клетка найдется, т.е., к ней есть путь, обрываем цикл и делаем обратную процедуру:
Ищем смежную клетку с номером, меньше того, что стоит в конечной, на единицу. Переходим туда и опять ищем смежную с меньшим на единицу номером. Запоминаем координаты каждой. И таким образом мы всегда дойдем до самой первой, т.е. той, в которой стоит единица. Найденый путь будет кратчайшим. Если путь вообще не существует, на n-ом шаге прямой процедуры не найдется необработынных смежных клеток. Такие дела.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
JekLove



Зарегистрирован: 22.02.2002
Сообщения: 41
Откуда: Новосибирск

СообщениеДобавлено: Пт Фев 22 2002 21:28    Заголовок сообщения: Re: Поиск кратчайшего пути Ответить с цитатой

Рассмотрим случай, когда имеется лабиринт в виде матрицы. Алгоритм следующий. Заполняем все "дорожки" в лабиринте нулями. В начальную клетку записываем единицу. В смежные клетки,
которые являются "свободным пространством",
т.е., по которым можно ходить, пишем двойки. И так далее. Для каждой из клеток, обработанных на предыдущем шаге, повторяем процедуру: в каждую из смежных клеток, в которых стоит ноль, т.е., которые еще не обработаны, записываем номер текущего шага. Ну и на каждом шаге проверяем, является ли данная клетка конечной. Если эта клетка найдется, т.е., к ней есть путь, обрываем цикл и делаем обратную процедуру:
Ищем смежную клетку с номером, меньше того, что стоит в конечной, на единицу. Переходим туда и опять ищем смежную с меньшим на единицу номером. Запоминаем координаты каждой. И таким образом мы всегда дойдем до самой первой, т.е. той, в которой стоит единица. Найденый путь будет кратчайшим. Если путь вообще не существует, на n-ом шаге прямой процедуры не найдется необработынных смежных клеток. Такие дела.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...