普通的线性规划和区间规划里,一般题目有两种需求:
- 统计
- 最优解
- 约束规划
对输出结果添加条件–如01背包
题目链接
非决定性多项式(NP)
Non-deterministic Polynomial,不能在多项式时间复杂度内解决
时间复杂度
程序运行时间随着问题规模扩大的增长有多快
- 非多项式时间复杂度
指数级,如 O ( 2 n ) \mathcal{O}(2^n) O(2n), O ( 3 n ) \mathcal{O}(3^n) O(3n)
全排列, O ( n ! ) \mathcal{O}(n!) O(n!) - 多项式时间复杂度
O ( 1 ) \mathcal{O}(1) O(1) O ( n ) \mathcal{O}(n) O(n) O ( n l o g n ) \mathcal{O}(nlogn) O(nlogn) O ( n 2 ) \mathcal{O}(n^2) O(n2) O ( n 3 ) \mathcal{O}(n^3) O(n3)
多项式组合,计算机可接受
01背包
时间复杂度
O
(
n
∗
W
)
\mathcal{O}(n*W)
O(n∗W)
n是物品个数,W是限定的最大重量,根据W的精确度,算法复杂度可以变得相当巨大
如最小单元为0.001:
0.000 0.001 0.002 … 20.000
分配了20000个单元,计算量和存储量巨大
若要能覆盖从0到W的区间需要m位二进制数,则W可写作
2
m
2^m
2m
时间复杂度:
O
(
n
∗
2
m
)
\mathcal{O}(n*2^m)
O(n∗2m) -->非多项式时间复杂度