转载:澄清P问题、NP问题、NPC问题的概念

转载:澄清P问题、NP问题、NPC问题的概念

ID:47261825

大小:74.00 KB

页数:5页

时间:2019-09-01

转载:澄清P问题、NP问题、NPC问题的概念_第1页
转载:澄清P问题、NP问题、NPC问题的概念_第2页
转载:澄清P问题、NP问题、NPC问题的概念_第3页
转载:澄清P问题、NP问题、NPC问题的概念_第4页
转载:澄清P问题、NP问题、NPC问题的概念_第5页
资源描述:

《转载:澄清P问题、NP问题、NPC问题的概念》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、转载:澄清P问题、NP问题、NPC问题的概念你会经常看到网上出现“这怎么做,这不是NP问题吗”、“这个只有搜了,这已经被证明是NP问题了”之类的话。你要知道,大多数人此时所说的NP问题其实都是指的NPC问题。他们没有搞清楚NP问题和NPC问题的概念。NP问题并不是那种“只有搜才行”的问题,NPC问题才是。好,行了,基木上这个课解已经被澄清了。下面的内容都是在讲什么是P问题,什么是NP问题,什么是NPC问题,你如果不是很感兴趣就可以不看了。接下来你可以看到,把NP问题当成是NPC问题是一个多大的错误。还是先用儿句话简单说明一下时间复杂度。时间复杂度并不是表

2、示一个程序解决问题需要花多少时间,而是当问题规模扩人后,程序需要的时间长度增长得有多快。也就是说,对于高速处理数据的计算机来说,处理某一个特定数据的效率不能衡竝一个程序的好坏,而应该看当这个数据的规模变大到数百倍后,程序运行时间是否还是一样,或者也跟着慢了数百倍,或者变慢了数万倍。不管数据有多大,程序处理花的时间始终是那么多的,我们就说这个程序很好,具冇0(1)的时间复杂度,也称常数级复杂度;数据规模变得冇多大,花的时间也跟着变得有多长,这个程序的时间复杂度就是O(n),比如找n个数屮的最大值;而像冒泡排序、插入排序等,数据扩大2倍,吋间变慢4倍的,属于

3、0(22)的复杂度。还有一些穷举类的算法,所盂时间氏度成儿何阶数上涨,这就是0(a5)的指数级复杂度,甚至0(n!)的阶乘级复杂度。不会存在0(2^2)的复杂度,因为前面的那个“2”是系数,根木不会影响到整个程序的时间增长。同样地,0(23+22)的复杂度也就是0(23)的复杂度。因此我们会说,一个0(0.01*nA3)的程序的效率比O(100*22)的效率低,尽管在n很小的时候,前者优于麻者,但示者时间随数据规模增长得慢,最终0(23)的复杂度将远远超过0(22)。我们也说,0(2100)的复杂度小于0(1.015)的复杂度。容易看出,前面的几类复杂度

4、被分为两种级別,其中后者的复杂度无论如何都远远大于而者:一种是O(l),O(log(n)),O(2a)等,我们把它叫做多项式级的复杂度,因为它的规模n出现在底数的位置;另一种是O(aAn)和O(n!)型复杂度,它是非多项式级的,其复杂度计算机往往不能承受。当我们在解决一个问题时,我们选择的算法通常都需要是多项式级的复杂度,非多项式级的复杂度需要的时间太多,往往会超时,除非是数据规模非常小。自然地,人们会想到一个问题:会不会所有的问题都可以找到复杂度为多项式级的算法呢?很遗憾,答案是否定的。冇些问题甚至根本不可能找到一个正确的算法來,这称Z为“不可解问题"

5、(UndecidableDecisionProblem)0TheHaltingProblem就是一个著名的不可解问题,在我的MSNSpace上有过专门的介绍和证明。再比如,输出从1到n这n个数的全排列。不管你用什么方法,你的复杂度都是阶乘级,因为你总得用阶乘级的时间打印出结果来。冇人说,这样的“问题”不是一个"正规”的问题,正规的问题是让程序解决一个问题,输出一个“YES”或“NO”(这被称为判定性问题),或者一个什么什么的最优值(这被称为最优化问题)。那么,根据这个定义,我也能举岀一个不大可能会有多项式级算法的问题來:Hamilton回路。问题是这样的

6、:给你一个图,问你能否找到一条经过每个顶点一次且恰好一次(不遗漏也不重复)最后又走回来的路(满足这个条件的路径叫做Hamilton回路)。这个问题现在还没有找到多项式级的算法。事实上,这个问题就是我们麻曲要说的NPC问题。下面引入P类问题的概念:如果一个问题可以找到一个能在多项式的时间里解决它的算法,那么这个问题就属于P问题。P是英文单词多项式的第一个字付。哪些问题是P类问题呢?通常NOI和NOIP不会出不属于P类问题的题目。我们常见到的一些信息奥赛的题目都是P问题。道理很简单,一个用穷举换來的非多项式级时I'可的超时程序不会涵盖任何有价值的算法。接下來

7、引入NP问题的概念。这个就有点难理解了,或者说容易理解错误。在这里强调(回到我竭力想澄清的谋区上),NP问题不是非P类问题。吃回题是指可以在多题式的时I'可昱验诬一个解的回题。一NP」目题的另二个匡义是―可坯庭多项式的吐回黑猜出二个解的迥题.比方说,我RP很好,在程序中需要枚举时,我可以一猜一个准。现在某人拿到了一个求最短路径的问题,问从起点到终点是否有一条小于100个单位长度的路线。它根据数据画好了图,但怎么也算不出来,于是来问我:你看怎么选条路走得最少?我说,我RP很好,肯定能随便给你指条很短的路岀来。然示我就胡乱曲了几条线,说就这条吧。那人按我指的

8、这条把权值加起來一看,嘿,神了,路径长度98,比100小。于是答案出來了,存在比

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。