Лемма о белых путях — различия между версиями
(Новая страница: «{{Лемма |statement = Не существует такого момента выполнения [[Обход в глубину, цвета вершин|поис…») |
м (rollbackEdits.php mass rollback) |
||
(не показано 14 промежуточных версий 4 участников) | |||
Строка 3: | Строка 3: | ||
Не существует такого момента выполнения [[Обход в глубину, цвета вершин|поиска в глубину]], в который бы существовало ребро из черной вершины в белую. | Не существует такого момента выполнения [[Обход в глубину, цвета вершин|поиска в глубину]], в который бы существовало ребро из черной вершины в белую. | ||
|proof = | |proof = | ||
− | Пусть в процессе выполнения процедуры <tex>dfs</tex> нашлось ребро из черной вершины <tex>v</tex> в белую вершину <tex>u</tex>. Рассмотрим момент времени, когда мы запустили <tex>dfs(v)</tex>. В этот момент вершина <tex>v</tex> была перекрашена из белого в серый, а вершина <tex>u</tex> | + | Пусть в процессе выполнения процедуры <tex>dfs</tex> нашлось ребро из черной вершины <tex>v</tex> в белую вершину <tex>u</tex>. Рассмотрим момент времени, когда мы запустили <tex>dfs(v)</tex>. В этот момент вершина <tex>v</tex> была перекрашена из белого в серый, а вершина <tex>u</tex> была белая. Далее в ходе выполнения алгоритма будет запущен <tex>dfs(u)</tex>, поскольку обход в глубину обязан посетить все белые вершины, в которые есть ребро из <tex>v</tex>. По алгоритму вершина <tex>v</tex> будет покрашена в черный цвет тогда, когда завершится обход всех вершин, достижимых из нее по одному ребру, кроме тех, что были рассмотрены раньше нее. Таким образом, вершина <tex>v</tex> может стать черной только тогда, когда <tex>dfs</tex> выйдет из вершины <tex>u</tex>, и она будет покрашена в черный цвет. Получаем противоречие. |
}} | }} | ||
<br> | <br> | ||
− | + | == Лемма о белых путях == | |
− | == Лемма о белых путях | ||
{{Лемма | {{Лемма | ||
|statement = | |statement = | ||
− | + | Пусть дан граф <tex>G</tex>. Запустим <tex>dfs(G)</tex>. Остановим выполнение процедуры <tex>dfs</tex> от какой-то вершины <tex>u</tex> графа <tex>G</tex> в тот момент, когда вершина <tex>u</tex> была выкрашена в серый цвет (назовем его первым моментом времени). Заметим, что в данный момент в графе <tex>G</tex> есть как белые, так и черные, и серые вершины. Продолжим выполнение процедуры <tex>dfs(u)</tex> до того момента, когда вершина <tex>u</tex> станет черной (второй момент времени). | |
+ | <br>Тогда вершины графа <tex>G\setminus u</tex>, бывшие черными и серыми в первый момент времени, не поменяют свой цвет ко второму моменту времени, а белые вершины либо останутся белыми, либо станут черными, причем черными станут те, что были достижимы от вершины <tex>u</tex> по белым путям. | ||
|proof = | |proof = | ||
− | + | Черные вершины останутся черными, потому что цвет может меняться только по схеме белый <tex>\to</tex> серый <tex>\to</tex> черный. Серые останутся серыми, потому что они лежат в стеке рекурсии и там и останутся. | |
+ | <br>Далее докажем два факта: | ||
+ | {{Утверждение | ||
+ | |statement= | ||
+ | Если вершина была достижима по белому пути в первый момент времени, то она стала черной ко второму моменту времени. | ||
+ | |proof = | ||
+ | Если вершина <tex>v</tex> была достижима по белому пути из <tex>u</tex>, но осталась белой, это значит, что во второй момент времени на пути из <tex>u</tex> в <tex>v</tex> встретится ребро из черной вершины в белую, чего не может быть по лемме, доказанной выше. | ||
}} | }} | ||
+ | {{Утверждение | ||
+ | |statement= | ||
+ | Если вершина стала черной ко второму моменту времени, то она была достижима по белому пути в первый момент времени. | ||
+ | |proof = | ||
+ | Рассмотрим момент, когда вершина <tex>v</tex> стала черной: в этот момент существует cерый путь из <tex>u</tex> в <tex>v</tex>, а это значит, что в первый момент времени сущестовал белый путь из <tex>u</tex> в <tex>v</tex>, что и требовалось доказать. | ||
+ | }} | ||
+ | Отсюда следует, что если вершина была перекрашена из белой в черную, то она была достижима по белому пути, и что если вершина как была, так и осталась белой, она не была достижима по белому пути, что и требовалось доказать. | ||
+ | }} | ||
+ | |||
+ | [[Категория: Алгоритмы и структуры данных]] | ||
+ | [[Категория: Обход в глубину]] |
Текущая версия на 19:28, 4 сентября 2022
Лемма: |
Не существует такого момента выполнения поиска в глубину, в который бы существовало ребро из черной вершины в белую. |
Доказательство: |
Пусть в процессе выполнения процедуры | нашлось ребро из черной вершины в белую вершину . Рассмотрим момент времени, когда мы запустили . В этот момент вершина была перекрашена из белого в серый, а вершина была белая. Далее в ходе выполнения алгоритма будет запущен , поскольку обход в глубину обязан посетить все белые вершины, в которые есть ребро из . По алгоритму вершина будет покрашена в черный цвет тогда, когда завершится обход всех вершин, достижимых из нее по одному ребру, кроме тех, что были рассмотрены раньше нее. Таким образом, вершина может стать черной только тогда, когда выйдет из вершины , и она будет покрашена в черный цвет. Получаем противоречие.
Лемма о белых путях
Лемма: | ||||||||||
Пусть дан граф . Запустим . Остановим выполнение процедуры от какой-то вершины графа в тот момент, когда вершина была выкрашена в серый цвет (назовем его первым моментом времени). Заметим, что в данный момент в графе есть как белые, так и черные, и серые вершины. Продолжим выполнение процедуры до того момента, когда вершина станет черной (второй момент времени).
Тогда вершины графа , бывшие черными и серыми в первый момент времени, не поменяют свой цвет ко второму моменту времени, а белые вершины либо останутся белыми, либо станут черными, причем черными станут те, что были достижимы от вершины по белым путям. | ||||||||||
Доказательство: | ||||||||||
Черные вершины останутся черными, потому что цвет может меняться только по схеме белый
| ||||||||||