数据结构:第1讲:算法分析

目录

  1. 时间复杂度
  2. 空间复杂度

1. 时间复杂度

1.1

时间复杂度也称渐近时间复杂度,T(n) = O(f(n)),意思是时间和算法的复杂度是成正比的,算法执行时间越长,算法就越复杂。

注:程序运行的总时间主要和两点有关:
(1)执行每条语句的耗时(无法判断)。
(2)每条语句的执行频率。

注:所谓的算法分析并非分析实际执行所需要的时间,而是针对算法中语句的执行次数做出估计,从中得到算法执行时间的信息。

注:语句的频度就是语句的执行次数。

1.2 时间复杂度计算

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

(2)例题:

1.3

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

比如上面那道题,若 n 为 0,则f(n) = 1,所以T(n) = O(1)?错误,答案不变。

1.4 常量阶

只要 f(n) 是一个准确的数字,都写成 O(1)。

1.5 平方阶

1.6 立方阶

频度为 n + 1 直接写成 n 即可。

1.7 对数阶

1.8 时间复杂度汇总

1.9 例题

2.空间复杂度(了解即可)

空间复杂度主要用来描述某个算法对应的程序想在计算机上执行,除了用来存储代码和输入数据的内存空间外,还需要额外的空间。

S(n) = O(f(n))。

相关推荐
05候补工程师2 小时前
【硬核干货】用“算法”思维袭英语新题型:集合逆清晰除与降维打击解题法
经验分享·笔记·考研·算法·学习方法
白藏y3 小时前
【数据结构】简单选择排序
数据结构·算法·排序算法
信奥胡老师3 小时前
B3930 [GESP202312 五级] 烹饪问题
开发语言·数据结构·c++·学习·算法
许长安3 小时前
Redis 跳表实现详解
数据库·c++·经验分享·redis·笔记·缓存
paeamecium3 小时前
【PAT甲级真题】- Shortest Distance (20)
数据结构·c++·算法·pat考试·pat
折哥的程序人生 · 物流技术专研3 小时前
《Java 100 天进阶之路》第23篇:缓冲区数据结构 ByteBuffer
java·开发语言·数据结构·后端·面试·求职招聘
June bug3 小时前
【雅思学习笔记】Part2话题词汇及表达
笔记·学习
Hehuyi_In4 小时前
postgres-howto 学习笔记
笔记·学习·postgresql·脚本·how to
图码4 小时前
矩阵操作优化:从 O(q×n) 到 O(q) 的优雅进阶
数据结构·线性代数·算法·性能优化·矩阵·python3.11