NP (độ phức tạp)

Bách khoa toàn thư mở Wikipedia
Bước tới: menu, tìm kiếm

Trong lý thuyết độ phức tạp tính toán, NP là viết tắt của "nondeterministic polynomial time" (thuật toán bất định trong thời gian đa thức). Cụ thể hơn, NP là tập hợp các bài toán quyết định giải được trong thời gian đa thức bởi máy Turing bất định. Một định nghĩa khác của NP là tập hợp các bài toán quyết định mà trong trường hợp câu trả lời là "có", tồn tại một chứng minh có độ dài đa thức có thể kiểm chứng được trong thời gian đa thức bởi máy Turing tất định.

Định nghĩa[sửa | sửa mã nguồn]

Một thuật toán kiểm chứng V cho ngôn ngữ A là một thuật toán (tất định) sao cho

  • Với mọi chuỗi x trong ngôn ngữ A, tồn tại chuỗi y sao cho V(x,y)=1.
  • Với mọi chuỗi x không nằm trong A, V(x,y)=0 với mọi y.

Thời gian thực thi của V được tính theo tham số là độ dài của x.

NP được định nghĩa là tập hợp các ngôn ngữ/bài toán có thuật toán kiểm chứng chạy trong thời gian đa thức.

Ví dụ[sửa | sửa mã nguồn]

Quan hệ với các lớp bài toán khác[sửa | sửa mã nguồn]

NP là tập hợp con của EXPTIME, MA.

NP=PCP(log n, O(1)) [1]

Ghi chú[sửa | sửa mã nguồn]

  1. ^ S. Arora, C. Lund, R. Motwani, M. Sudan, and M. Szegedy. “Proof verification and hardness of approximation problems”. Journal of the ACM 45(3):501-555, 1998. ECCC TR98-008.