Теоремы Карзанова о числе итераций алгоритма Диница в сети с целочисленными пропускными способностями — различия между версиями
м |
м (rollbackEdits.php mass rollback) |
||
(не показаны 2 промежуточные версии 2 участников) | |||
Строка 69: | Строка 69: | ||
Положим, что <tex>F > C^{\frac{1}{3}}|V|^{\frac{2}{3}}</tex>, и рассмотрим последнюю фазу, в которой поток <tex>f</tex> не превышает <tex>F - C^{\frac{1}{3}}|V|^{\frac{2}{3}}</tex>. В этот момент осталось не более <tex>C^{\frac{1}{3}}|V|^{\frac{2}{3}} + 1</tex> фаз, и <tex>G_f</tex> {{---}} сеть с максимальным потоком <tex>F - |f| \geqslant C^{\frac{1}{3}}|V|^{\frac{2}{3}}</tex>. Мы можем применить Лемму(3), чтобы оценить длину <tex>l</tex> слоистой сети, и, соответственно, количество выполненных фаз: | Положим, что <tex>F > C^{\frac{1}{3}}|V|^{\frac{2}{3}}</tex>, и рассмотрим последнюю фазу, в которой поток <tex>f</tex> не превышает <tex>F - C^{\frac{1}{3}}|V|^{\frac{2}{3}}</tex>. В этот момент осталось не более <tex>C^{\frac{1}{3}}|V|^{\frac{2}{3}} + 1</tex> фаз, и <tex>G_f</tex> {{---}} сеть с максимальным потоком <tex>F - |f| \geqslant C^{\frac{1}{3}}|V|^{\frac{2}{3}}</tex>. Мы можем применить Лемму(3), чтобы оценить длину <tex>l</tex> слоистой сети, и, соответственно, количество выполненных фаз: | ||
− | <tex>l \leqslant |V|{(\dfrac{2C}{F-|f|})}^{\frac{1}{2}} - 1 \leqslant 2^{\frac{1}{2}}C^{\frac{1}{3}}|V|^{\frac{2}{3}} - 1</tex>. | + | <tex>l \leqslant |V|{\left(\dfrac{2C}{F-|f|}\right)}^{\frac{1}{2}} - 1 \leqslant 2^{\frac{1}{2}}C^{\frac{1}{3}}|V|^{\frac{2}{3}} - 1</tex>. |
Таким образом, прошло <tex>O(C^{\frac{1}{3}}|V|^{\frac{2}{3}})</tex> фаз, и <tex>O(C^{\frac{1}{3}}|V|^{\frac{2}{3}})</tex> фаз осталось. | Таким образом, прошло <tex>O(C^{\frac{1}{3}}|V|^{\frac{2}{3}})</tex> фаз, и <tex>O(C^{\frac{1}{3}}|V|^{\frac{2}{3}})</tex> фаз осталось. |
Текущая версия на 19:12, 4 сентября 2022
Содержание
Обозначения
Введём следующие обозначения:
- сеть с целочисленными пропускными способностями, —
- обозначим и как максимальный поток,
- ,
- ,
- — потенциал вершины ,
- — общий потенциал,
- остаточная сеть. —
Теоремы
Лемма (1): |
Пусть — расстояние между и в исходной сети, максимальный поток в этой сети равен .
Тогда . |
Доказательство: |
Пусть сохранения потока, если обозначить как любой допустимый поток, то единиц потока должно проходить через . Но суммарное количество потока, которое может проходить через любую вершину не превосходит её потенциала. Отсюда, если обозначить как общий потенциал вершин из , то мы имеем: — расстояние между и , а — набор вершин, удаленных от на . — разъединяющее множество узлов: при его удалении исчезают все пути из в . Следуя закону
для любого допустимого потока . В частности, , таким образом получаем: |
Лемма (2): |
Пусть — сеть, а — допустимый поток в этой сети. Тогда общий потенциал в остаточной сети равен общему потенциалу . |
Доказательство: |
По теореме о декомпозиции поток можно разбить на множество простых путей из в и циклов. Рассмотрим каждый путь (цикл) и убедимся, что, пуская по нему поток , потенциал вершины не изменится. Действительно, рассмотрим вершину , поток в неё течёт по ребру , а из неё по ребру . Пусть — функция пропускных способностей в остаточной сети после пропускания потока по -ому пути (циклу). Рассмотрим . , а , сложив эти два значения, получим, что остаётся неизменной. Применив такое же рассуждение для , получим, что потенциал каждой вершины остаётся неизменным. |
Теорема (Первая теорема Карзанова): |
Число итераций алгоритма Диница в сети ( — исток, — сток) с целочисленными пропускными способностями — . |
Доказательство: |
Пусть — максимальный поток в сети . Теорема верна для , так как после каждой фазы поток увеличивается хотя бы на . Если , рассмотрим последнюю фазу, на момент начала выполнения которой поток в сети был меньше, чем . После этого потребуется не больше фаз, чтобы найти максимальный поток. На предыдущей фазе поток ( ) в был не больше , таким образом .— сеть с максимальным потоком и потенциалом (по Лемме(2)). Поэтому можно воспользоваться Леммой(1), чтобы оценить расстояние между и в , и получить оценку длины слоистой сети: Так как каждая фаза увеличивает длину слоистой сети минимум на один, то осуществляется не больше фаз. Таким образом происходит не более фаз. |
Лемма (3): |
Пусть в сети параллельных рёбер. Пусть — максимальный поток в . Тогда расстояние между и в таково: . нет |
Доказательство: |
Обозначим Таким образом как набор вершин на расстоянии от . Множества и определяют разрез . Пропускная способность этого разреза не больше , так как все рёбра между и также являются рёбрами между и и не более чем двумя параллельными рёбрами, исходящими из какой-то вершины в остаточной сети. По теореме о максимальном потоке/минимальном разрезе, . ограничен наименьшим из . Но эта величина максимальна, когда для , таким образом , из чего следует необходимое неравенство. |
Теорема (Вторая теорема Карзанова): |
Число итераций алгоритма Диница с целочисленными пропускными способностями — . |
Доказательство: |
Если , то теорема очевидна. Положим, что , и рассмотрим последнюю фазу, в которой поток не превышает . В этот момент осталось не более фаз, и — сеть с максимальным потоком . Мы можем применить Лемму(3), чтобы оценить длину слоистой сети, и, соответственно, количество выполненных фаз:Таким образом, прошло . фаз, и фаз осталось. |