Алгоритм нахождения Гамильтонова цикла в условиях теорем Дирака и Оре — различия между версиями
Ak57 (обсуждение | вклад) (→Доказательство алгоритма) |
Ak57 (обсуждение | вклад) (→Доказательство алгоритма) |
||
Строка 28: | Строка 28: | ||
* между ними ребра нет, и тогда надо найти такую вершину <tex>\mathrm{v}_j</tex>, что <tex>\mathrm{v}_k \mathrm{v}_j, | * между ними ребра нет, и тогда надо найти такую вершину <tex>\mathrm{v}_j</tex>, что <tex>\mathrm{v}_k \mathrm{v}_j, | ||
\mathrm{v}_{k+1} \mathrm{v}_{j+1} \in \mathbb{E}</tex>; | \mathrm{v}_{k+1} \mathrm{v}_{j+1} \in \mathbb{E}</tex>; | ||
− | + | Покажем, что такая вершина обязательно найдется. | |
− | + | Пусть <tex>S= \{ i| \mathrm{e}_i = \mathrm{v}_k \mathrm{v}_i \in \mathbb{E}\} | |
− | Пусть <tex>S= \{ i| \mathrm{e}_i = \mathrm{v} | + | \subset \{1, 2, ...,n\} \setminus \{\mathrm{k},\mathrm{k+1}\} |
− | \subset \{ | + | </tex> и <tex>T = \{ i| f_i=\mathrm{v}_2 \mathrm{v}_{i+1} \in \mathbb{E} \} |
\subset \{2, 3, ...,n-1\}</tex>. | \subset \{2, 3, ...,n-1\}</tex>. | ||
Тогда <tex>S \cup T \subset \{2,3,...,n\}</tex>, откуда <tex>|S \cup T |< n</tex>. Но <tex>|S|+|T| = \operatorname{deg}\ v_1 + \operatorname{deg}\ v_2 \ge n</tex> по условию [[Теорема Оре|теоремы Оре]] или [[Теорема Дирака|теоремы Дирака]], в зависимости от наших начальных условий. А значит <tex>S \cap T \ne \varnothing</tex>, следовательно искомая вершина обязательно найдется. | Тогда <tex>S \cup T \subset \{2,3,...,n\}</tex>, откуда <tex>|S \cup T |< n</tex>. Но <tex>|S|+|T| = \operatorname{deg}\ v_1 + \operatorname{deg}\ v_2 \ge n</tex> по условию [[Теорема Оре|теоремы Оре]] или [[Теорема Дирака|теоремы Дирака]], в зависимости от наших начальных условий. А значит <tex>S \cap T \ne \varnothing</tex>, следовательно искомая вершина обязательно найдется. |
Версия 20:09, 6 ноября 2013
Содержание
Описание алгоритма
Алгоритм находит гамильтонов цикл в неориентированном графе , если выполняются условия теоремы Оре или выполнена теорема Дирака. Рассмотрим перестановку вершин , где . Если между каждой парой соседних вершин в перестановке существует ребро, то мы получили Гамильтонов цикл. В противном случае, начиная с пары , начнем последовательно рассматривать пары соседних вершин , пока (Когда , за считаем ).
- Если между ними есть ребро, то переходим к следующей паре вершин .
- Если же ребра нет, то найдем такую вершину
- Если то перевернем часть перестановки от до (включительно).
- Если обменяем в перестановке элементы на позициях и , где , то есть считаем равной . Например, если , то и поменяются местами, а останется на месте.
(то, что она всегда существует, будет показано ниже), что , и существуют ребра и (Если , то за считаем ).
Псевдокод
for i = 1 to n // перебираем все вершины перестановкиif // если нет ребра между for // перебираем все остальные вершины if && // если есть ребра reverse_subsequence( ) // разворачиваем часть перестановки от i+1 позиции до j break // переходим к следующей итерации внешнего for |
Доказательство алгоритма
На
-ой итерации внешнего цикла рассматриваются вершины . Возможно 2 случая:- между ними есть ребро, и тогда делать ничего не надо;
- между ними ребра нет, и тогда надо найти такую вершину , что ;
Покажем, что такая вершина обязательно найдется. Пусть теоремы Оре или теоремы Дирака, в зависимости от наших начальных условий. А значит , следовательно искомая вершина обязательно найдется. Теперь заметим, что после -ой итерации внешнего цикла между всеми парами вершин , где существует ребро, а значит после итераций мы найдем цикл.
и . Тогда , откуда . Но по условиюСложность алгоритма
Алгоритм работает за
. Действительно, количество итераций внешнего цикла всегда равно . Во внутреннем цикле в худшем случае будет выполнено итерации, получаем время работы .