leetcode算法笔记-算法复杂度

对于时间复杂度,主要包括三种情况:

渐进紧确界:

O渐进上界:

渐进下界:

加法原则:不同的时间复杂度相加取阶数最高的

乘法原则:不同的时间复杂度相乘,结果为时间复杂度的乘积

阶乘时间复杂度一般出现在全排列和旅行商问题中,而对数时间复杂度一般出现在分治算法中。

对于平均时间复杂度举例

python 复制代码
def find(nums, val):
    pos = -1
    for i in range(n):
        if nums[i] == val:
            pos = i
            break
    return pos

在这个代码中,最好时间复杂度为O(1),最坏时间复杂度为O(n)。这样时间复杂度就不唯一,所以此时我们需要计算平均时间复杂度。对于这个算法总共有n+1种情况,即在n个位置上找到指定元素和最终没有找到指定元素。对其求平均即可得,所以平均时间复杂度就为O(n)。

空间时间复杂度的计算就较为简单,主要包括局部变量所占用的存储空间和进行递归时所使用的堆栈空间。 一般将算法的辅助空间作为评判算法空间复杂度大小的标准。

相关推荐
峰顶听歌的鲸鱼5 分钟前
16.docker:存储
运维·笔记·docker·容器·云计算
少许极端5 分钟前
算法奇妙屋(二十一)-两个数组或字符串的dp问题(动态规划)
算法·动态规划·两个数组或字符串的dp问题
草莓熊Lotso5 分钟前
《算法闯关指南:递归,搜索与回溯算法--递归》--04. 两两交换链表中的结点 ,05.Pow(x,n)
数据结构·算法·链表
week_泽6 分钟前
OpenCV图像拼接实践笔记(第一部分)
人工智能·笔记·opencv
Bruce_kaizy8 分钟前
c++图论——最短路之Johnson算法
开发语言·数据结构·c++·算法·图论
BahTiYar_14 分钟前
ctfshow Web应用安全与防护系列
笔记·web安全
七月七3316 分钟前
半小时搞定GitHub学生认证
笔记·github
蒙奇D索大18 分钟前
【数据结构】排序算法精讲 | 交换排序全解:交换思想、效率对比与实战代码剖析
数据结构·笔记·考研·算法·排序算法·改行学it
sin_hielo20 分钟前
leetcode 1351
数据结构·算法·leetcode
睡醒了叭21 分钟前
图像分割-传统算法-边缘分割
图像处理·opencv·算法·计算机视觉