数据结构:第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))。

相关推荐
Cloud_Shy6186 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第三章 Item 21 - 24)
开发语言·人工智能·笔记·python·迭代器模式
计算机安禾7 小时前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
nnsix7 小时前
Unity HybirdCLR 简单了解 笔记
笔记
指针战神8 小时前
synchronized简易版Redis版跳表实现(注释干货)
数据结构
handler019 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
中屹指纹浏览器9 小时前
指纹浏览器环境克隆、批量派生的风控隐患剖析与标准化新建环境实操指南
经验分享·笔记
.千余9 小时前
【C++】C++手写Vector容器:从底层源码模拟实现
开发语言·c++·经验分享·笔记·学习
元直数字电路验证9 小时前
云计算实验笔记(四):容器编排(Container Orchestration)
运维·笔记·docker·云计算
自小吃多10 小时前
某志步进电机驱动器故障排查标准流程
笔记
zhangrelay11 小时前
后智能时代智能体推演预测娱乐文-节选-
笔记·学习·娱乐