Совершенное паросочетание в дереве
Разница между ru1 и ru2, 0 символ(ов) изменены
Привет codeforces!↵

Какой самый простой способ проверить есть ли в дереве совершенное паросочетание?↵

Может быть [алгоритм Куна](https://neerc.ifmo.ru/wiki/index.php?title=Алгоритм_Куна_для_поиска_максимального_паросочетания)? :)↵

Скорее всго вы подумали про динамику по поддеревьям. Действительно это хороший способ, ведь он работает за размер ввода. Однако есть более простой способ проверить имеет ли дерево полное паросочетание.↵

Пусть $sz_v$ — размер поддерева $v$-й вершины. Тогда я утверждаю, что совершенное паросочетание есть тогда и только тогда, когда ровно половина всех $sz_v$ четная.↵

Доказательство:↵

Пусть $sz_{odd}$ — количество нечетных поддеревьев, а $sz_{even}$ — количетво четных поддеревьев.↵

Сначала докажем, что $sz_{even} \leq sz_{odd}$.↵

Заметим, что $sz_v = \sum_{u}^{} sz_u + 1$ ($u$ — ребенок $v$). Если $sz_v$ четно, то хотя-бы один из детей $u$ имеет нечетный размер поддерева, потому что их сумма нечетная. Сопоставим в пару каждому четному $sz_v$ нечетное $sz_u$ ($u$ — ребенок $v$). Таким образом $sz_{even} \leq sz_{odd}$. Более того, мы доказали, что если $sz_{even} = sz_{odd}$, то в дереве есть совершенное паросочетание, явно выбрав каждому четному $sz_v$ пару.↵

Теперь докажем, что если $sz_{even} \neq sz_{odd}$, то в дереве нет полного паросочетания. Допустим есть. Тогда в нем есть ребро, соединяющее $v, u$, такие что $sz_v \equiv sz_u \equiv 1\space (mod\space 2)$. Пусть $v$ — родитель $u$. Тогда заметим, что каждое ребро либо целиком содержится в поддереве $v$, либо нет. В обоих случаях ребро забирает из поддерева $v$ четное количество вершин, а значит и суммарно они заберут четное количество вершин, но $sz_v \equiv 1\space(mod\space 2)$ — противоречие.↵

Таким образом $sz_{odd} = sz_{even}$ равносильно наличию полного паросочетания.↵

Спасибо за прочтение!

История

 
 
 
 
Правки
 
 
  Rev. Язык Кто Когда Δ Комментарий
en5 Английский PvPro 2024-12-02 00:52:42 1 Tiny change: 'sz_{even} {\leq sz_{o' -> 'sz_{even} \leq sz_{o'
en4 Английский PvPro 2024-12-02 00:52:29 175
ru3 Русский PvPro 2024-12-02 00:48:37 75
en3 Английский PvPro 2024-12-02 00:19:07 0 (published)
en2 Английский PvPro 2024-12-02 00:18:48 138 (saved to drafts)
en1 Английский PvPro 2024-12-02 00:15:26 1802 Initial revision for English translation
ru2 Русский PvPro 2024-12-02 00:07:38 0 (опубликовано)
ru1 Русский PvPro 2024-12-02 00:05:46 1907 Первая редакция (сохранено в черновиках)