NL-полнота задачи о достижимости в графе
Версия от 14:48, 6 апреля 2010; Joshik (обсуждение | вклад)
Содержание
Формулировка задачи
Даны ориентированный граф
и две вершины в нем. Необходимо проверить, правда ли, что в графе существует путь из вершины в вершину . Эту задачу принято называть или .Утверждение
Задача NL-полна.
Доказательство
Для доказательства NL-полноты необходимо показать, что эта задача NL-трудная и принадлежит классу NL.
Доказательство принадлежности задачи STCON классу NL
Для доказательства необходимо предъявить алгоритм для недетерминированной машины Тьюринга, который использует конечное число переменных, каждая из которых занимает
памяти, где - размер входа для задачи и за время порядка решает эту задачу.Алгоритм:
1. Начиная с вершины
недетерминированно переходит в одну из вершин, смежных с ней. (Очевидно, для этого необходимо конечное число переменных)2. Проверяет, правда ли, что текущая вершина совпадает с
. Если это так, возвращает TRUE.3. Отдельно считает количество пройденных вершин. Как только это число превышает количество вершин в графе, то алгоритм возвращает FALSE, так как посетил некоторую вершину дважды.
Таким образом в каждый момент алгоритму достаточно хранить текущую вершину, количество посещенных вершин, финальную вершину
и некоторое число вспомогательных переменных, для совершения переходов. Все эти переменные принимают значения не более, чем максимальный номер вершины, то есть как раз занимают памяти.Так как, если из
существует путь в , то он имеет длину не более, чем количество вершин в графе, то алгоритм корректно возвращает FALSE.