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)。

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

相关推荐
Bingorl1 分钟前
机器学习之朴素贝叶斯算法
人工智能·算法·机器学习
8Qi82 分钟前
LeetCode 209. 长度最小的子数组(Minimum Size Subarray Sum)
java·算法·leetcode·双指针·滑动窗口
哇嘎呀8 分钟前
OSPF笔记
网络·笔记
Upsy-Daisy8 分钟前
IOTA 学习笔记(三):IOTA 的技术演进路线
笔记·学习
有个人神神叨叨17 分钟前
Agent Memory 学习笔记-1.0
笔记·学习
狮子座明仔25 分钟前
DeCoRL:把推理链拆成“乐团合奏“——AAAI 2026 一篇把 RLHF 推到 32B 打 GPT-4o 的工作
人工智能·深度学习·算法
QiLinkOS26 分钟前
合肥气链科技有限公司创办与未来技术应用
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
妄想出头的工业炼药师32 分钟前
追踪定位大模型
算法·开源
Solis程序员34 分钟前
TreeMap 核心原理与实战
java·数据结构·算法
一只肥瘫瘫34 分钟前
STM32 程序升级学习笔记:Bootloader、IAP 与串口升级流程
笔记·stm32·学习