Задать вопрос
Lite_stream
@Lite_stream

Дейкстра почти за линейное время (для неориентированного графа)?

Подумал, что если так получилось, что в графе много мостов и средний размер двуссвязной компоненты небольшой, например, порядка логарифма от числа вершин, то можно намного эффективнее запустить Дейсктру:

1. Найти все мосты - O(n)
2. Запустить дейкстру от каждой двусвязной компоненты:
всего компонент: n/logn
обработка одной компоненты: log^2(n) или logn * log(logn)). на практике конечно для таких маленьких подгарфов использовать массив за log^2(n) вместо кучи за logn * log(logn))
итого: n/logn * log^2(n) = n * logn для массива (но тут с очень маленькой константой) или n/logn * logn * log(logn)) = n * log(logn) асимптотически лучше, но на практике должно быть лучше с массивом за log^2 на обработку компоненты
3. Затем просто O(n) пересчитать расстояния от S до всех по формуле: D(s, vi) + d(vi, vj) как префикс расстояния, думаю из картинки будет понятно
66d3413b2387d219621524.png

Подумал, что такое не так и редко встречается, например, в сетевом роутинге вроде бы именно такая картика, где много мостов и размер компонент двусвязности мал
  • Вопрос задан
  • 98 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
wataru
@wataru Куратор тега Алгоритмы
Разработчик на С++, экс-олимпиадник.
В сетевом роутинге, в основном, нет* центрального узла с информацией о всей топологии, чтобы искать пути. Так что там вообще не работает Дейкстра, а работают распределенные алгоритмы.

А так, да, на очень специфичных гарфах всеядный алгоритм Дейкстры не самый лучший вариант. И ваш алгоритм тут получается быстрее.

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

Войдите, чтобы написать ответ

Похожие вопросы