Задача о динамической связности — различия между версиями
(→Обобщение задачи для произвольных графов) |
(→Обобщение задачи для произвольных графов) |
||
Строка 31: | Строка 31: | ||
− | Введём функцию <tex>l(e):e{\rightarrow}[0;\mathrm{\log} n]</tex> и назовём её ''уровнем ребра''. Будем рассматривать графы <tex>G_i={ | + | Введём функцию <tex>l(e):e{\rightarrow}[0;\mathrm{\log} n]</tex> и назовём её ''уровнем ребра'' <tex>e<\tex>. Будем рассматривать графы <tex>G_i=<tex>\langle V, E\rangle</tex>{E|l(E) \geqslant i}<\tex> |
<!--При выполнении операции add что-то хорошее, а с удалением не всё так просто.--> | <!--При выполнении операции add что-то хорошее, а с удалением не всё так просто.--> |
Версия 23:46, 7 января 2018
Задача: |
Есть неориентированный граф из вершин, изначально не содержащий рёбер. Требуется обработать запросов трёх типов:
|
В этой статье будет приведено решение задачи online, то есть отвечать на get-запрос (проверять наличие пути между вершинами) мы будем сразу.
Содержание
Динамическая связность в лесах
Если задача такова, что в графе нет и не может быть циклов, то она сводится к задаче о связности в деревьях эйлерова обхода. Время работы каждого запроса для упрощённой задачи — .
Обобщение задачи для произвольных графов
Существуют задачи, в которых граф не обязательно на протяжении нашей работы после каждой операции добавления ребра остаётся лесом. Но мы можем в каждой компоненте связности выделить остовные деревья, которые образуют остовный лес.
Введём функцию
и назовём её уровнем ребра {E|l(E) \geqslant i}<\tex>