152
правки
Изменения
Нет описания правки
Можно найти компоненты реберной двусвязности за один проход, используя стек.
Псевдокод:
'''void paint(int v):
maxcolor++;
while (пока вершина стека не вершина <tex>v</tex> и стек не пустой)
извлекаем вершину стека и красим её;
'''void dfs(вершина v, предок вершины p):
добавляем вершину в в стек;
state[v] = 1; ret[v] = enter[v] = ++time;
для всех вершин u смежных v:
если (u == parent):
переходим к следующей итерации
если (state[u] = 1):
ret[v] = min(ret[v], enter[u]);
иначе:
если (state[u] = 0):
dfs(u, v); ret[v] = min(ret[v], ret[u]);
если (enter[v] < ret[u]):
paint(u); state[v] = 2;
Итоговое время работы алгоритма <tex> O(|V| + |E|)</tex>.
== См. также Визуализатор ==* [[Обход в глубину, цвета вершин|Oбхода в глубину]]* [[Использование обхода в глубину для поиска точек сочленения]]* [[Построение компонент вершинной двусвязности]]* [[Использование обхода в глубину для поиска мостов]]
* [http://rain.ifmo.ru/cat/view.php/vis/graph-general/bridges-2001| Визуализация построение компонент реберной двусзяности]