Изменения

Перейти к: навигация, поиск

Коды Прюфера

2479 байт добавлено, 19:06, 4 сентября 2022
м
rollbackEdits.php mass rollback
== Коды Алгоритм построения кодов Прюфера ==
Кодирование Прюфера переводит [[Количество помеченных деревьев#Помеченное дерево|помеченные деревья порядка <tex>n</tex>]] в последовательность чисел от <tex>1</tex> до <tex>n</tex> по алгоритму:<br>
Пока количество вершин больше двух:
# Вершина <tex>v</tex> и инцидентное ей ребро удаляются из дерева.
<br>
Полученная последовательность называется '''кодом Прюфера''' ''(англ: Codes Priifer. Prüfer code)'' для заданного дерева.
{{Лемма
# Вершина с номером <tex>n</tex> не может быть удалена, следовательно на последнем шаге у неё была смежная вершина, и число <tex>n</tex> встретилось в коде.
# Если вершина не является листом, то у неё на некотором шаге была смежная вершина <tex>-</tex> лист, следовательно номер этой вершины встречается в коде.
# Если вершина является листом с номером меньше <tex>n</tex>, то она была удалена до того, как был удален ее её сосед, следовательно ее её номер не встречается в коде.
Таким образом, номера всех вершин, не являющихся листьями или имеющих номер <tex>n</tex>, встречаются в коде Прюфера, а остальные <tex>-</tex> нет.
для которого эта последовательность является кодом Прюфера.
|proof=
Доказательство проведем по индукции. по числу <tex>n</tex><br><u>''База. индукции:''</u> <tex>n = 1</tex> <tex>-</tex> верно. <bru>''Индукционный переход:''</u>Переход от Пусть для числа <tex>n</tex> к верно, построим доказательство для <tex>n + 1</tex>.:<br>
Пусть у нас есть последовательность: <tex>A = [a_1, a_2, ..., a_{n - 2}].</tex>
Выберем минимальное число <tex>v</tex> не лежащее в <tex>A</tex>. По предыдущей лемме <tex>v</tex> <tex>-</tex> вершина, которую мы удалили первой. Соединим <tex>v</tex> и <tex>a_1</tex> ребром. Выкинем из последовательности <tex>A</tex> число <tex>a_1</tex>. Перенумеруем вершины, для всех <tex>a_i > v</tex> заменим <tex>a_i</tex> на <tex>a_i - 1</tex>. А теперь мы можем применить предположение индукции.
== Пример построения кода Прюфера ==
[[Файл: Prufer.png|500px]]
 
== Алгоритм декодирования кодa Прюфера ==
 
В массиве вершин исходного дерева <tex>V</tex> найдём вершину <tex>v_{min}</tex> с минимальным номером, не содержащуюся в массиве с кодом Прюфера <tex>P</tex>, т.е. такую, что она является листом или концом уже добавленного в граф ребра, т.е. она стала листом в процессе построения кода Прюфера (по первому пункту построения). Вершина <tex>p_1</tex> была добавлена в код Прюфера как инцидентная листу с минимальным номером (по второму пункту построения), поэтому в исходном дереве существует ребро {<tex>p_1</tex>, <tex>v_{min}</tex>}, добавим его в список ребер. Удалим первый элемент из массива <tex>Р</tex>, а вершину <tex>v_{min}</tex> - из массива <tex>V</tex> т.к. она больше не может являться листом (по третьему пункту построения). Будем выполнять вышеуказанные действия, пока массив <tex>P</tex> не станет пустым. В конце работы алгоритма в массиве <tex>V</tex> останутся две вершины, составляющие последнее ребро дерева (это следует из построения).
 
=== Реализация ===
# P - код Прюфера
# V - вершины
'''function''' buildTree(P, V):
'''while'' '''not'' P.empty():
u = P[0]
v = min(x '''<tex>\in</tex>''' V: P.count(x) == 0)
G.push({u, v})
P.erase(0)
V.erase(indexOf(v))
G.push({v[0], v[1]})
'''return''' G
 
== Пример декодирования кода Прюфера ==
==См. также==
*[[Связь матрицы Кирхгофа и матрицы инцидентности]]* [[Матрица Кирхгофа]]*[[Количество помеченных деревьев]]*[[Подсчет числа остовных деревьев с помощью матрицы Кирхгофа]] 
== Источники информации ==
* [http://www.intuit.ru/department/algorithms/graphsuse/11/2.html Интернет Университет INTUIT | Представление с помощью списка ребер и кода Прюфера]
[[Категория: Алгоритмы и структуры данных]]
[[Категория: Остовные деревья ]]
[[Категория: Свойства остовных деревьев ]]
1632
правки

Навигация