[一步步学数据结构与算法 03]-时间与空间复杂度(上)

一、什么是复杂度分析?

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)(立方阶)
非多项式阶:随着数据规模的增长,算法的执行时间和空间占用暴增,这类算法性能极差。包括,
O(2^n)(指数阶)、O(n!)(阶乘阶)

五、如何掌握好复杂度分析方法?

复杂度分析关键在于多练,所谓孰能生巧。

六、常见时间复杂度

常见时间复杂度

复杂度比较

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 数据结构中的排序算法的空间时间复杂度取决于实施算法时所使用的方法,但一般来说,插入排序,选择排序,冒泡排序和希尔排序的时间复杂度为O(n^2),空间复杂度为O(1)。归并排序的时间复杂度为O(nlogn),空间复杂度为O(n)。快速排序的时间复杂度为O(nlogn),空间复杂度为O(logn)。 ### 回答2: 数据结构中的排序算法有许多种,每种算法在不同的情况下具有不同的时间空间复杂度。 1. 冒泡排序:时间复杂度为O(n^2),空间复杂度为O(1)。 2. 插入排序:时间复杂度为O(n^2),空间复杂度为O(1)。 3. 选择排序:时间复杂度为O(n^2),空间复杂度为O(1)。 4. 归并排序:时间复杂度为O(nlogn),空间复杂度为O(n)。 5. 快速排序:时间复杂度为O(nlogn),空间复杂度为O(logn)。 6. 堆排序:时间复杂度为O(nlogn),空间复杂度为O(1)。 7. 希尔排序:时间复杂度为取决于增量序列的选择,最坏情况下为O(n^2),空间复杂度为O(1)。 8. 计数排序:时间复杂度为O(n+k),其中k是待排序数组中的最大值,空间复杂度为O(n+k)。 9. 基数排序:时间复杂度为O(d*(n+r)),其中d是数字的位数,r是基数,空间复杂度为O(n+r)。 总的来说,大多数排序算法的时间复杂度为O(nlogn),其中n是待排序的元素个数。空间复杂度的差异在于是否需要额外的空间来存储中间结果。有些排序算法需要额外的空间来存储中间结果,而另一些排序算法则是在原地进行排序,不需要额外的空间。 ### 回答3: 数据结构中的各种排序算法的空间时间复杂度如下: 1. 冒泡排序: - 时间复杂度:平均情况和最坏情况下为O(n^2),最好情况下为O(n)。 - 空间复杂度:O(1)。 2. 选择排序: - 时间复杂度:平均情况、最坏情况和最好情况下都是O(n^2)。 - 空间复杂度:O(1)。 3. 插入排序: - 时间复杂度:平均情况和最坏情况下为O(n^2),最好情况下为O(n)。 - 空间复杂度:O(1)。 4. 快速排序: - 时间复杂度:平均情况下为O(nlogn),最坏情况下为O(n^2),最好情况下为O(nlogn)。 - 空间复杂度:平均情况下为O(logn),最坏情况下为O(n)。 5. 归并排序: - 时间复杂度:平均情况、最坏情况和最好情况下都是O(nlogn)。 - 空间复杂度:O(n)。 6. 堆排序: - 时间复杂度:平均情况、最坏情况和最好情况下都是O(nlogn)。 - 空间复杂度:O(1)。 7. 计数排序: - 时间复杂度:平均情况、最坏情况和最好情况下都是O(n+k),其中k是非负整数的范围。 - 空间复杂度:O(n+k)。 8. 桶排序: - 时间复杂度:平均情况、最坏情况和最好情况下都是O(n+k),其中k是桶的数量。 - 空间复杂度:O(n+k)。 9. 基数排序: - 时间复杂度:平均情况、最坏情况和最好情况下都是O(d*n),其中d是数字位数,n是元素个数。 - 空间复杂度:O(n)。 以上是常见的排序算法的时间空间复杂度,需要根据具体情况选择合适的算法来满足需求。不同排序算法适用于不同规模和特点的数据集。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值