算法时间复杂度和NP问题简介

Posted outthinker

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法时间复杂度和NP问题简介相关的知识,希望对你有一定的参考价值。

这里主要简单说一下算法的时间复杂度和NP问题简介,毕竟分析算法的时间复杂度上界有助于分析算法的好坏,分析算法好坏也有助于分析是否还有更好的算法;

一、时间复杂度:

一般关心的还有递归问题中的时间复杂度:(参考:http://blog.csdn.net/so_geili/article/details/53444816

例:

二、NP(Non-determinstic polynnomial)问题:

P类问题:可以在多项式时间内使用确定性算法求解的判定问题;

NP类问题:可以在多项式时间内使用非确定性算法求解的判定问题;

NPC问题(NP完全问题):NP中的某些问题的复杂性与整个类的复杂性相关联.这些问题中任何一个如果存在多项式时间的算法,那么所有NP问题都是多项式时间可解的;

注意:(1)这里的多项式时间的时间针对的是问题的规模;

           (2)我们将可以在多项式时间内求解的问题称为“易”问题,将需要在指数时间内求解的问题称为“难”问题;

           (3)从定义很容易发现P属于NP,但P是不是NP的真子集,这个问题目前是世界七大难题之一;

           (4)判定问题的定义可以参见下面这个例子:

            

 

以上是关于算法时间复杂度和NP问题简介的主要内容,如果未能解决你的问题,请参考以下文章

算法课笔记系列——NP问题及其计算复杂性

计算机算法设计与分析——NP

算法基础 -- 简介时间复杂度与空间复杂度

P和NP问题

机器学习周志华p=np是啥意思

np背包问题算法:折半枚举