DAA-P 및 NP 클래스
컴퓨터 과학에서는 일부 값을 최대화하거나 최소화하는 것이 목적인 경우 많은 문제가 해결되지만 다른 문제에서는 해결책이 있는지 여부를 찾으려고합니다. 따라서 문제는 다음과 같이 분류 할 수 있습니다.
최적화 문제
최적화 문제는 목표가 일부 값을 최대화하거나 최소화하는 것입니다. 예를 들면
주어진 그래프에 색상을 지정하는 데 필요한 최소 색상 수 찾기.
그래프에서 두 꼭지점 사이의 최단 경로 찾기.
결정 문제
대답이 예 또는 아니오 인 많은 문제가 있습니다. 이러한 유형의 문제는 decision problems. 예를 들면
주어진 그래프를 4 색으로 만 색칠 할 수 있는지 여부.
그래프에서 Hamiltonian주기를 찾는 것은 결정 문제가 아니지만 그래프를 확인하는 것은 Hamiltonian인지 아닌지 결정 문제입니다.
언어는 무엇입니까?
모든 결정 문제에는 예 또는 아니오의 두 가지 대답 만있을 수 있습니다. 따라서 의사 결정 문제는 특정 입력에 대해 '예'라고 대답하면 언어에 속할 수 있습니다. 언어는 대답이 예인 입력의 총합입니다. 이전 장에서 논의 된 대부분의 알고리즘은polynomial time algorithms.
입력 크기 n, 알고리즘의 최악의 경우 시간 복잡성이 O(nk), 어디 k 상수이고 알고리즘은 다항식 시간 알고리즘입니다.
Matrix Chain Multiplication, Single Source Shortest Path, All Pair Shortest Path, Minimum Spanning Tree 등과 같은 알고리즘은 다항식 시간으로 실행됩니다. 그러나 출장 영업 사원, 최적의 그래프 색상 지정, 해밀턴 사이클, 그래프에서 가장 긴 경로 찾기, 다항식 시간 알고리즘이 알려지지 않은 부울 공식 충족과 같은 많은 문제가 있습니다. 이러한 문제는 다음과 같은 흥미로운 종류의 문제에 속합니다.NP-Complete 상태를 알 수없는 문제.
이 맥락에서 우리는 다음과 같이 문제를 분류 할 수 있습니다.
P- 클래스
클래스 P는 다항식 시간에 풀 수있는 문제로 구성됩니다. 즉, 이러한 문제는 시간 내에 해결 될 수 있습니다. O(nk) 최악의 경우 k 일정합니다.
이러한 문제를 tractable, 다른 사람은 intractable or superpolynomial.
공식적으로 알고리즘은 다항식 시간 알고리즘입니다. p(n) 알고리즘이 크기의 모든 인스턴스를 해결할 수 있도록 n 한 번에 O(p(n)).
요구하는 문제 Ω(n50) 해결하는 시간은 본질적으로 다루기 어렵습니다. n. 가장 잘 알려진 다항식 시간 알고리즘은 제 시간에 실행됩니다.O(nk) 상당히 낮은 가치 k.
다항식 시간 알고리즘 클래스를 고려할 때의 장점은 모두 합리적이라는 것입니다. deterministic single processor model of computation 최대 다항식 slow-d로 서로 시뮬레이션 할 수 있습니다.
NP- 클래스
NP 클래스는 다항식 시간에서 확인할 수있는 문제로 구성됩니다. NP는 약간의 추가 정보를 사용하여 주장 된 답변의 정확성을 쉽게 확인할 수있는 결정 문제 클래스입니다. 따라서 우리는 해결책을 찾는 방법을 요구하는 것이 아니라 주장 된 해결책이 실제로 올바른지 확인하기 위해서만 있습니다.
이 클래스의 모든 문제는 철저한 검색을 사용하여 기하 급수적으로 해결 될 수 있습니다.
P 대 NP
결정적 다항식 시간 알고리즘으로 해결할 수있는 모든 결정 문제는 다항식 시간 비 결정적 알고리즘으로도 해결할 수 있습니다.
P의 모든 문제는 다항식 시간 알고리즘으로 해결할 수 있지만 NP-P의 모든 문제 는 다루기 어렵습니다.
여부는 알려져 있지 않습니다 P = NP. 그러나 NP에는 P에 속하면 P = NP임을 증명할 수 있다는 특성으로 많은 문제가 알려져 있습니다.
만약 P ≠ NP, P 또는 NP-Complete에없는 NP에 문제가 있습니다.
문제는 수업에 속한다 P문제에 대한 해결책을 찾는 것이 쉬운 경우. 문제는NP, 찾기가 매우 지루했을 수있는 솔루션을 확인하기 쉬운 경우.