Теорема Иммермана — различия между версиями
Akhi (обсуждение | вклад) |
Akhi (обсуждение | вклад) |
||
| Строка 28: | Строка 28: | ||
counter := 0 //''количество уже найденных и выведенных элементов'' | counter := 0 //''количество уже найденных и выведенных элементов'' | ||
'''for''' v = 1 .. n '''do''' //''перебираем все вершины графа'' | '''for''' v = 1 .. n '''do''' //''перебираем все вершины графа'' | ||
| − | ''continue or find path'' //''недетерминировано выбираем переходить к следующей вершине или угадываем путь до данной'' | + | ''continue or find path'' |
| + | //''недетерминировано выбираем переходить к следующей вершине или угадываем путь до данной'' | ||
counter++ | counter++ | ||
write v //''выводим вершину, до которой угадали путь'' | write v //''выводим вершину, до которой угадали путь'' | ||
Версия 16:36, 6 апреля 2010
Теорема Иммермана
Утверждение теоремы
NL = coNL
Доказательство
Решим задачу STNONCON на логарифмической памяти.
- нет пути из в в графе
Чтобы показать, что STNONCON входит в NL, можно придумать недетерминированый алгоритм, использующий памяти, который проверяет достижима ли вершина t из s.
Чтобы показать правильность работы алгоритма необходимо показать:
- В случае недостижимости t из s недетерминированые выборы приводят алгоритм к единице.
- Если t достижима из s, то вне зависимости от недетерминированых выбором, совершаемых алгоритмом, результат ноль.
Определим Ri = {v: существует путь из s в v длиной ≤ i}. Другими словами это множество всех вершин, достижимых из s не более чем за i шагов. Обозначим |Ri| за ri. Заметим, что если , где n = |V|, то не существует путь s в t в графе G, то есть ∈ STNONCON.
Лемма: Можно построить алгоритм, который по данному ri будет перечислять все вершины из Ri и удачно завершаться на логарифмической памяти. Если ri больше истинного размера Ri, то алгоритм завершится неудачно; однако если ri меньше истинного размера Ri, то алгоритм завершится удачно, но перечислит лишь некое подмножество Ri.
Enum(s, i, r_i, G)
counter := 0 //количество уже найденных и выведенных элементов
for v = 1 .. n do //перебираем все вершины графа
continue or find path
//недетерминировано выбираем переходить к следующей вершине или угадываем путь до данной
counter++
write v //выводим вершину, до которой угадали путь
if counter ≥ r_i then //нашли r_i вершин, удачно завершаем работу
ACCEPT
REJECT //не нашли r_i вершин
Enum перебирает все вершины на логарифмической памяти и пытается угадать путь до этой вершины из s.