时间复杂度

一、算法要满足的重要特征

1、 有穷性

2、确定性

3、可行性

4、输入

5、输出

二、程序运行的总时间

执行每条语句的耗时(与硬件相关)+每条语句执行的频率

cpp 复制代码
for(int i = 1;i <= n;i ++) //频度为n+1次 
{
	for(int j = 1;j <= n;j ++) //频度为n*(n+1)次
	{
		c[i][j] = 0; //频度为n*n  
		for(int k = 1;k <= n;k ++)//频度为n*n*(n+1)次
		{
			c[k][j] = 0; //频度为n*n*n 
		}
	}
}

在计算算法时间复杂度时,可以忽略所有低次幂和最高次幂的系数,这样可以简化算法分析

比如上面代码的时间复杂度就是:

f(n) = 2n^3+3n^2+2n+1 即:O(n^3)
注:

(1)对算法时间复杂度的度量,通常只讨论算法在最坏情况下的时间复杂度

(2)只要可以得出确切的数字,不管是一万还是一亿,时间复杂度都是O(1)

三、例子

x++;

s=0;

时间复杂度为O(1)
for(int i = 1;i <= 1000000;i ++) //频度为n+1次

{

}

时间复杂度为O(1)
for(int i = 1;i <= n;i ++) //频度为n+1次

{

}

时间复杂度为O(n)
x++;

s=0;

for(int i = 1;i <= n;i ++) //频度为n+1次

{

for(int j = 1;j <= n;j ++) //频度为n*(n+1)次

{

}

}

for(int i = 1;i <= n;i ++) //频度为n+1次

{

}

时间复杂度为O(n^2)
for(int i = 1;i <= n;i ++) //频度为n+1次

{

for(int j = 1;j <= i;j ++) //频度为n*(n+1)/2次

{

for(int k = 1;k <= j;k ++)

{

}

}

}

时间复杂度为O(n^3)
for(int i = 1;i <= n;i = i*2)

{

x ++;

s = 0;

}

时间复杂度为O(log2(n))

计算:

次数 1 2 3 4 t

i 1 2 4 8 ?

i 2^0 2^1 2^2 2^3 2^(t-1)

2^(t-1) = n 就可以算出来t = log2(n)

**总结:**计算复杂的时间复杂度时,要列表

相关推荐
董董灿是个攻城狮11 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员18 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish18 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱19 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者1 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮1 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者2 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考2 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx2 天前
CART决策树基本原理
算法·机器学习
Wect2 天前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript