时间复杂度

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

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)

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

相关推荐
李泽辉_14 分钟前
深度学习算法学习(一):梯度下降法和最简单的深度学习核心原理代码
深度学习·学习·算法
꧁Q༒ོγ꧂17 分钟前
算法详解---大纲
算法
m0_6038887123 分钟前
Scaling Trends for Multi-Hop Contextual Reasoning in Mid-Scale Language Models
人工智能·算法·ai·语言模型·论文速览
Xの哲學26 分钟前
Linux io_uring 深度剖析: 重新定义高性能I/O的架构革命
linux·服务器·网络·算法·边缘计算
comli_cn33 分钟前
残差链接(Residual Connection)
人工智能·算法
Aaron158840 分钟前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
予枫的编程笔记42 分钟前
【论文解读】DLF:以语言为核心的多模态情感分析新范式 (AAAI 2025)
人工智能·python·算法·机器学习
im_AMBER1 小时前
Leetcode 99 删除排序链表中的重复元素 | 合并两个链表
数据结构·笔记·学习·算法·leetcode·链表
王老师青少年编程1 小时前
信奥赛C++提高组csp-s之欧拉回路
c++·算法·csp·欧拉回路·信奥赛·csp-s·提高组
墨有6661 小时前
数学分析栈的出栈顺序:从算法判断到数学本质(卡特兰数初探)
c++·算法·数学建模