跳到主要内容

01| 复杂度分析

一、概述

PASS:我感觉很多东西都是基于不同数据结构实现的,所以我觉得我应该优先把这个看完,再去考虑学习别的进阶,我相信能够事半功倍。
复杂度分析我觉得是学习数据结构算法的基础,相当于程序的调试模式,要先会复杂度,才能考虑下一步的计划,我想多练习一些复杂度的分析,能够更快更好的掌握复杂度分析。

一.什么是复杂度分析?

1、 数据结构和算法解决是“如何让计算机更快时间、更省空间的解决问题”;
2、 因此需从执行时间和占用空间两个维度来评估数据结构和算法的性能;
3、 分别用时间复杂度和空间复杂度两个概念来描述性能问题,二者统称为复杂度;
4、 复杂度描述的是算法执行时间(或占用空间)与数据规模的增长关系;

二.为什么要进行复杂度分析?

1、 和性能测试相比,复杂度分析有不依赖执行环境、成本低、效率高、易操作、指导性强的特点;
2、 掌握复杂度分析,将能编写出性能更优的代码,有利于降低系统开发和维护成本;

三.如何进行复杂度分析?

1、大O表示法

1)来源
算法的执行时间与每行代码的执行次数成正比,用T(n) = O(f(n))表示,其中T(n)表示算法执行总时间,f(n)表示每行代码执行总次数,而n往往表示数据的规模。
2)特点
以时间复杂度为例,由于时间复杂度描述的是算法执行时间与数据规模的增长变化趋势,所以常量阶、低阶以及系数实际上对这种增长趋势不产决定性影响,所以在做时间复杂度分析时忽略这些项。

2、复杂度分析法则

1)单段代码看高频:比如循环。
2)多段代码取最大:比如一段代码中有单循环和多重循环,那么取多重循环的复杂度。
3)嵌套代码求乘积:比如递归、多重循环等
4)多个规模求加法:比如方法有两个参数控制两个循环的次数,那么这时就取二者复杂度相加。

四.常用的复杂度级别

多项式阶:随着数据规模的增长,算法的执行时间和空间占用,按照多项式的比例增长。包括,
O(1)(常数阶)、O(logn)(对数阶)、O(n)(线性阶)、O(nlogn)(线性对数阶)、O(n2)(平方阶)、O(n3)(立方阶)
非多项式阶:随着数据规模的增长,算法的执行时间和空间占用暴增,这类算法性能极差。包括,