Теорема о существовании простого пути в случае существования пути — различия между версиями
Shevchen (обсуждение | вклад) |
Shevchen (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
+ | {{Теорема | ||
+ | |statement= | ||
+ | Если между двумя вершинами графа существует путь, то между ними существует простой путь. | ||
+ | |proof= | ||
+ | Для доказательства этой теоремы введём два определения. | ||
{{Определение | {{Определение | ||
|definition= | |definition= | ||
'''Простой (вершинно-простой) путь''' между двумя вершинами графа – путь между ними, в котором каждая из вершин графа встречается не более одного раза. | '''Простой (вершинно-простой) путь''' между двумя вершинами графа – путь между ними, в котором каждая из вершин графа встречается не более одного раза. | ||
}} | }} | ||
− | |||
{{Определение | {{Определение | ||
|definition= | |definition= | ||
Строка 9: | Строка 13: | ||
}} | }} | ||
− | + | * Доказательство построением: | |
− | + | ||
− | + | Возьмём любой из существующих путей <math>V_0E_1V_1E_2V_2 ... E_nV_n</math>. | |
− | + | ||
− | Возьмём любой из существующих путей <math>V_0E_1V_1E_2V_2 ... E_nV_n</math>. Для вершины <math>V_i</math> найдём момент её последнего вхождения в путь – <math>V_j</math> | + | Алгоритм: |
+ | 1. Для вершины <math>V_i</math> найдём момент её последнего вхождения в путь – <math>V_j</math>. | ||
+ | 2. Удалим отрезок пути от <math>E_{i+1}</math> до <math>V_j</math>, включительно. | ||
+ | Получившаяся последовательность вершин и рёбер графа останется путём от <math>V_0</math> до <math>V_n</math>, и в нём вершина <math>V_i</math> будет содержаться ровно один раз. | ||
+ | Начнём процесс с вершины <math>V_0</math> и будем повторять его каждый раз для следующей вершины нового пути, пока не дойдём до последней. По построению, получившийся путь будет содержать каждую из вершин графа не более одного раза, а значит, будет простым. | ||
* Альтернативное: | * Альтернативное: | ||
− | Выберем из всех путей между данными вершинами путь наименьшей длины. Пусть он не простой | + | Выберем из всех путей между данными вершинами путь наименьшей длины. |
+ | |||
+ | Предположение: | ||
+ | Пусть он не простой. | ||
+ | Тогда в нём содержатся две одинаковые вершины <math>V_i = V_j</math>, <math>i < j</math>. Удалим из исходного пути отрезок от <math>E_{i+1}</math> до <math>V_j</math>, включительно. Конечная последовательность также будет путём от <math>V_0</math> до <math>V_n</math> и станет короче исходной. Получено противоречие с условием: взятый нами путь оказался не кратчайшим. Значит, предположение неверно, выбранный путь – простой. | ||
}} | }} |
Версия 00:49, 11 октября 2010
Теорема: | ||||
Если между двумя вершинами графа существует путь, то между ними существует простой путь. | ||||
Доказательство: | ||||
Для доказательства этой теоремы введём два определения.
Возьмём любой из существующих путей .Алгоритм: 1. Для вершинынайдём момент её последнего вхождения в путь – . 2. Удалим отрезок пути от до , включительно. Получившаяся последовательность вершин и рёбер графа останется путём от до , и в нём вершина будет содержаться ровно один раз. Начнём процесс с вершины и будем повторять его каждый раз для следующей вершины нового пути, пока не дойдём до последней. По построению, получившийся путь будет содержать каждую из вершин графа не более одного раза, а значит, будет простым.
Выберем из всех путей между данными вершинами путь наименьшей длины. Предположение: Пусть он не простой.Тогда в нём содержатся две одинаковые вершины , . Удалим из исходного пути отрезок от до , включительно. Конечная последовательность также будет путём от до и станет короче исходной. Получено противоречие с условием: взятый нами путь оказался не кратчайшим. Значит, предположение неверно, выбранный путь – простой. | ||||