Сложностные классы RP и coRP
Определение классов RP и coRP
Классы языков RP и coRP определяются следующим образом:
В этих определениях - это вероятностная машина Тьюринга, время работы которой ограничено полиномом от длины входа.
Теорема о равенстве ZPP и пересечения RP и coRP
Поскольку ранее было доказано утверждение о равенстве классов ZPP и ZPP', можно записать утверждение этой теоремы в виде:
Доказательство.
Пусть язык . Нужно показать, что .
Алгоритм для вероятностной машины Тьюринга из определения класса RP будет выглядеть так:
(x){ switch ((x)) { case 0: return 0; case 1: return 1; case ?: return 0; // выдала ответ "не знаю" } }
Так как машина выдает ответ "не знаю" с вероятностью не больше одной второй, а в ответах 0 или 1 никогда не ошибается, вероятность правильного ответа в случае, если слово принадлежит языку, будет не меньше одной второй, а слово не из языка всегда будет обнаружено, что соответствует определению класса RP.
Аналогичным образом доказывается, что :
(x){ switch ((x)) { case 0: return 0; case 1: return 1; case ?: return 1; // выдала ответ "не знаю" } }
Осталось показать, что . То есть если и , то .
Пусть - вероятностная машина Тьюринга для языка из определения RP, а - соответствующая машина из определения coRP. Тогда алгоритм для машины из определения ZPP' будет устроен следующим образом:
(x){ if ((x)) return 1; else if (!(x)) return 0; return ?; //возвращаем ответ "не знаю" }