Jump to content

Алгоритм ближайшего соседа

(Перенаправлено из алгоритма ближайшего соседа )
Алгоритм ближайшего соседа
Сорт Алгоритм аппроксимации
Структура данных График
Худшая производительность
Наихудшая пространственная сложность
Оптимальный Нет

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

Алгоритм

[ редактировать ]

Вот шаги алгоритма:

  1. Инициализируйте все вершины как непосещенные.
  2. Выберите произвольную вершину, установите ее как текущую вершину u . Отметить вас как посещенный.
  3. Найдите кратчайшее ребро, соединяющее текущую вершину u и непосещенную вершину v .
  4. Установите v как текущую вершину u . Отметить v как посещенный.
  5. Если все вершины в домене посещены, завершить работу. В противном случае перейдите к шагу 3.

Последовательность посещенных вершин является результатом работы алгоритма.

Алгоритм ближайшего соседа легко реализовать и быстро выполняется, но иногда он может пропускать более короткие маршруты, которые легко заметить с помощью человеческого понимания, из-за его «жадного» характера. В целом, если последние несколько этапов тура сопоставимы по продолжительности с первыми этапами, то тур является разумным; если они намного больше, то вполне вероятно, что существуют гораздо лучшие туры. Другая проверка — использовать такой алгоритм, как алгоритм нижней границы , чтобы оценить, достаточно ли хорош этот тур.

В худшем случае алгоритм дает тур, который намного длиннее оптимального. Точнее, для каждой константы r существует пример задачи коммивояжера, в котором длина тура, вычисленная алгоритмом ближайшего соседа, больше, чем в r раз длина оптимального тура. Более того, для каждого количества городов заданы расстояния между городами, для которых эвристика ближайшего соседа дает уникальный наихудший возможный тур. (Если алгоритм применяется к каждой вершине в качестве начальной, лучший найденный путь будет лучше, чем по крайней мере N/2-1 других обходов, где N — количество вершин.) [1]

Алгоритм ближайшего соседа может вообще не найти возможный обход, даже если он существует.

Примечания

[ редактировать ]
  1. ^ Г. Гутин, А. Йео и А. Зверович, 2002 г.
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 44b02259cf065d0f75cd7d42b27e3ece__1715372520
URL1:https://arc.ask3.ru/arc/aa/44/ce/44b02259cf065d0f75cd7d42b27e3ece.html
Заголовок, (Title) документа по адресу, URL1:
Nearest neighbour algorithm - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)