P、NP、NP-hard、NPC问题超简单理解

查了好多资料,现在网上的资料都不说人话,简单的问题故意写得让别人看懂不以显示自己的水平很高深?真正的大师难道不是把复杂问题说得很简单的人?把简单问题说得让别人看不懂显得自己很高深的就是煞笔。

多项式定义:就是一元N次方式,时间复杂度为多项式的问题都很容易解出来

各类问题关系图: (结合以下文字说明看)
在这里插入图片描述

问题定义:

  1. P问题:一个问题可以在多项式(O(n^k))的时间复杂度内解决(简单的问题);
    例如:n个数的排序问题(不超过O(n^2))

  2. NP问题:一个问题的解可以在多项式的时间内被证实或证伪,即给出一个答案,可以很快地(在多项式时间内)验证这个答案是对的还是错的,但是不一定能在多项式时间求出正确的解;
    例如: 背包客问题,任何一条路线方案都可以很快地被计算代价,但是无法在多项式时间内求出最优解。

  3. NP-hard问题:假设存在这样一个问题,1)任意np问题都可以在多项式时间内归约为该问题;2)解决了该问题就解决了NP问题;这个问题就是NP-hard问题;
    即为了解决问题A,先将问题A归约为另一个问题B,解决问题B同时也间接解决了问题A。问题B就是一个NP-hard问题;
    范围: 无多项式时间求解算法且不一定能在多项式时间内验证解的问题
    例如,停机问题。

  4. NPC问题:**理解一:**如果存在一个问题可以在多项式时间内验证解的正确性,其他问题也可以归约为该问题,解决了该问题就解决了NP问题,该问题就是NPC问题。
    理解二: 存在这样一个NP问题,所有的NP问题都可以约化成它。换句话说,只要解决了这个问题,那么所有的NP问题都解决了。其定义要满足2个条件: 1) 首先,它得是一个NP问题;2) 然后,所有的NP问题都可以约化到它。
    要证明npc问题的思路就是:
    先证明它至少是一个NP问题,再证明其中一个已知的NPC问题能约化到它。
    范围: NPC问题既是NP问题,也是NP-hard问题。
    例如,SAT问题(第一个NPC问题)。该问题的基本意思是,给定一系列布尔变量以及它的约束集,是否存在一个解使得它的输出为真。

参考文献:
1.https://blog.csdn.net/qq_21768483/article/details/80430590
2.https://www.zhihu.com/question/27039635

  • 16
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

THMAIL

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值