本文总结至什么是P问题、NP问题和NPC问题
首先说明时间复杂度,时间复杂度是指当数据扩大之后,算法需要增长的时间有多长。比如我们扩大了数据之后,算法进行计算得出结果的时间与扩大之前所用的时间是相同的,那么时间复杂度就是O(1),也称常数复杂度,这里的O(f(n))可以理解为高数中的等价无穷小。还有以O(log(n)),O(n^a) 等为时间复杂度的算法,这种类型的时间复杂度,我们把它叫做多项式级的复杂度,因为它的规模n出现在底数的位置。另一种是O(n!)或n位于指数位置的,它是非多项式级的,通常计算都很复杂。但并不是所有算法都能用不是特别复杂的多项式级复杂度来解决。也就出现了各种问题。
P问题,指可以用多项式级复杂度的算法来解决。
NP问题,不是非P类问题,它是指可以在多项式级复杂度中验证的问题。就是说,解决的过程不是多项式级复杂度,但是解是多项式级复杂度。举个例子就是说,教会1+1等于几比较复杂,但是我计算1+1=2就不难。在原文中,作者说到:信息学中的号称最困难的问题——“NP问题”,实际上是在探讨NP问题与P类问题的关系。
NPC问题,是指所有NP问题都可以约化到该问题的NP问题。一个问题A可以约化为问题B的含义即是,可以用问题B的解法解决问题A。前提是要以多项式级的转化。
NP-Hard问题,是指是指所有NP问题都可以约化到该问题的问题,但是这个问题不一定是NP问题。