P就是能在多项式时间内解决的问题;

NP就是能在多项式时间验证答案正确与否的问题。

P是否等于NP实质上就是在问,如果对于一个问题我能在多项式时间内验证其答案的正确性,那么我是否能在多项式时间内解决它?

再说说NP-hardness和NP-completenes. 这里涉及一个概念,不妨称为问题之间的归约。可以认为各个问题的难度是不同的,表现形式为,如果我可以把问题A中的一个实例转化为问题B中的一个实例,然后通过解决问题B间接解决问题A,那么就认为B比A更难。通过对归约过程做出限制可以得到不同类型的归约。

这里的“问题”一般形式化为判定问题,如:三班是否有同学刷知乎。
P: 我能在多项式时间内判定三班是否有同学刷知乎。
NP: 我能在多项式时间内判定你给定的某个人(如:王二)是否证明了这个问题(王二在三班且王二刷知乎)。
也就是说,对于一个判定性问题,如果其能在多项式时间内得到判定,则是P的;如果能在多项式时间内验证一个证据(上文中的王二)是否证明出此问题,则其是NP的。

这里又要说道归约上了。如果A能用多项式次的B解决,称A能多项式归约到B。
比如说现在问题A为判定二年级是否有人刷知乎, 那我可以把这个问题规约到问题B:判定每个班级是否有人刷知乎。 只要对二年级所有的班级做一边问题B,就能得到A的结果,如果这个次数是输入规模的多项式级别,我们认为A可以多项式规约到B。

NP问题有很多种,但若所有的NP问题都能多项式归约到问题X,X为NP hard,进一步如果X是NP的,称X是NP complete的。而事实上,的确所有的NP问题都可以规约到某一些NP问题,这类问题也就是经常出现的NP complete问题,比如TSP(旅行商)问题。

一般情况下非判定问题都可以转化为多项式时间次数的判定问题,所以P和NP的计算复杂度概念可以适用于几乎所有算法问题。现在可以知道,由于所有的NP问题都可以多项式规约到某一个NP Complete问题,所以只要一个NP Complete问题能在多项式时间内得到解决,那么所有的NP问题都可以在多项式时间内得到结局了。目前常见的计算机问题几乎都是NP的(多项式时间内能验证结果,大部分算法问题都满足),也就是说,如果能多项式解决某一个NP Complete问题,几乎所有的算法问题都能在多项式解决了,excited!

首先这些p和np都是用来描述解决一个问题需要的时间和它输入规模之间的关系…

P问题:

一个问题可以在多项式(O(n^k))的时间复杂度内解决

例如:n个数的排序(不超过O(n^2))


NP问题:

一个问题的解可以在多项式的时间内被证实或证伪

例如:典型的子集求和问题,给定一个整数集合求是否存在一个非空子集它的和为零。如给定集合s={-1,3,2,-5,6},很明显子集{3,2,-5}能满足问题,并且验证该解只需要线性时间复杂度就能被证实。


NP-hard问题:

任意np问题都可以在多项式时间内归约为该问题。归约的意思是为了解决问题A,先将问题A归约为另一个问题B,解决问题B同时也间接解决了问题A。

例如,停机问题。


NPC问题:

既是NP问题,也是NP-hard问题。

例如,SAT问题(第一个NPC问题)。该问题的基本意思是,给定一系列布尔变量以及它的约束集,是否存在一个解使得它的输出为真。


相互关系:
显然,所有P问题都是NP问题,反之则不一定。npc问题是np问题的子集,也是p问题和np问题的差异所在。如果找到一个多项式内能被解决的npc问题的解决方法,那么P=NP。

【详解】P问题、NP问题和NPC问题详解(千禧年问题之首)相关推荐

  1. P 问题、NP 问题、NPC 问题(NP 完全问题)、NPH 问题和多项式时间复杂度

    为了弄清楚上面的概念以及对他们有个基本的了解,所以总结出这篇blog. 1.多项式时间复杂度 定义: 解决问题需要的时间与问题的规模之间是多项式关系. 多项式关系形如 O ( n k ) O(n^k) ...

  2. P问题、NP问题、NPC问题(NP完全问题)、NPH问题和多项式时间复杂度

    https://blog.csdn.net/K346K346/article/details/51026006 1.多项式时间复杂度 定义: 解决问题需要的时间与问题的规模之间是多项式关系. 多项式关 ...

  3. 到底什么是P问题,NP问题,NPC问题,NP-hard问题?什么是规约(或约化)?

    我们在阅读paper时,经常会看到NP-hard,NP-complete等问题.我也是慢慢学习发现到这些问题的趣味,下面我们一起来探讨一下P,NP,NP-hard,NP-complete这些问题吧!在 ...

  4. 一文读懂什么是P问题、NP问题和NPC问题

    你会经常看到网上出现"这怎么做,这不是NP问题吗"."这个只有搜了,这已经被证明是NP问题了"之类的话.你要知道,大多数人此时所说的NP问题其实都是指的NPC问 ...

  5. P问题 NP问题 和 NPC问题

    转自Matrix67 这或许是众多OIer最大的误区之一. 你会经常看到网上出现"这怎么做,这不是NP问题吗"."这个只有搜了,这已经被证明是NP问题了"之类的 ...

  6. 【NP问题】P问题,NP问题,NPC问题,NPH问题

    P类问题: 官方定义:所有可以在多项式时间内求解的判定问题.(判定问题:判断是否有一种能够解决某一类问题的能行算法的研究课题.) 自己的理解:对于一类问题,能有一个确定性算法,在多项式时间内就能解出所 ...

  7. 算法:NP问题,NP完全问题(NPC),NPhard问题

    在做计算机算法关于NP完全问题这一章的作业的时候,发现有很多概念理解的不是很透彻,然后就反复看老师的讲义,在网上查阅各种资料,花了很多时间来弄懂这块的内容.发现书上的概念太正式,定义太标准,不容易很快 ...

  8. P问题、NP问题、NPC问题的概念及实例证明

    美剧<基本演绎法>(也就是美版"福尔摩斯")第 2 季第 2 集中,两位研究 NP 问题的数学家被谋杀了,凶手是同行,因为被害者即将证明"P=NP 问题&qu ...

  9. P问题、NP问题、NPC问题、NP难问题的概念[zz]

    你会经常看到网上出现"这怎么做,这不是NP问题吗"."这个只有搜了,这已经被证明是NP问题了"之类的话.你要知道,大多数人此时所说的NP问题其实都是指的NPC问 ...

  10. [zz]澄清P问题、NP问题、NPC问题的概念

     [zz]澄清P问题.NP问题.NPC问题的概念 这或许是众多OIer最大的误区之一.     你会经常看到网上出现"这怎么做,这不是NP问题吗"."这个只有搜了,这已经 ...

最新文章

  1. 09 Storage Structure and Relationships
  2. 同步通信和异步通信区别
  3. python函数名字_Python每日3题-为什么函数名字可以当做参数用?
  4. 5 分钟解决前后端联调问题,说一说前端代理这件事
  5. androidrunnable使用_Android Runnable 运行在那个线程
  6. Citrix StoreFront无法正常初始化
  7. 多元高斯分布是非参_(二)多元高斯分布与概率图条件独立性假设
  8. ubuntu下C语言编程的注意点
  9. 少儿C++编程如何入门
  10. 用python编写一个弹球游戏
  11. 防止多次快速点击打开多个activity的问题
  12. PID算法优化之积分器抗饱和处理
  13. winapi获取鼠标指向当前元素
  14. Window10 C盘清理经验
  15. 【SPSS】SPSS之相关系数矩阵(Pearson)
  16. 计算机应用基础任务教化2010,【计算机应用论文】茶文化下的计算机应用基础课程改革(共5535字)...
  17. 怎么关闭计算机硬件加速,启用硬件加速是什么意思?如何关闭[详细说明]
  18. DuerOS智能设备激活数破亿!百度补贴上亿造节再添一把火
  19. 最新版勤哲Excel服务器V2017.13.0.1无限用户支持手机APP,微信,任意安装,支持后续升级
  20. Linux内核结构组成之进程调度,老男孩linux运维期中架构

热门文章

  1. 在线Javascript美化格式化工具
  2. 荣耀路由器外界硬盘与win10
  3. SSM框架Web程序的流程(Spring SpringMVC Mybatis)
  4. 网站访问数据统计工具
  5. Unity 提取资源 Disunity、Unity Studio
  6. GD32F103 配置timer0输出PWM
  7. ES6阮一峰读书笔记第一章let和const命令
  8. excel相同字段多行合并_EXCEL里如何快速把多行数据合并为一行并以逗号隔开?...
  9. 可解释人工智能XAI
  10. 超详细的CentOS7的下载安装配置教程