算法的时间复杂度

整理了下算法的时间复杂度,跟大家一起分享下。

时间复杂度O 是表示算法运行时间与输入数据规模(通常用 n 表示)之间的关系。算法执行时间随输入数据规模增长的变化趋势。

1、O(1) --- 常数时间

  • 无论输入数据多大,执行时间固定不变
  • 典型场景:数组按索引访问、哈希表查询。

2、O(log n) --- 对数时间

  • 执行时间随数据量增长,但增速远慢于线性增长
  • 典型场景:二分查找、平衡二叉搜索树操作。

3、O(n) --- 线性时间

  • 执行时间与数据量成正比
  • 典型场景:遍历数组/链表、线性搜索。

4、O(n log n) --- 线性对数时间

  • 比线性慢,但比平方快,常见于高效排序算法
  • 典型场景:快速排序、归并排序、堆排序。

5、O(n²) --- 平方时间

  • 执行时间与数据量的平方成正比,数据量大时性能急剧下降。
  • 典型场景:冒泡排序、选择排序、暴力搜索(如两数之和的暴力解法)。

6、O(2ⁿ) --- 指数时间

  • 执行时间呈指数级增长,仅适用于极小规模数据
  • 典型场景:暴力穷举、未优化的递归(如斐波那契数列原始递归)。

7、O(n!) --- 阶乘时间

  • 最慢的时间复杂度,通常用于全排列问题
  • 典型场景:全排列生成。

排序从最优到最差:O(1) < O(log n) < O(n) < O(n log n) < O(n^2) < O(2^n) < O(n!)。

空间复杂度的表示与时间复杂度的表示基本一致。时间复杂度关注的是运行时间 ,空间复杂度关注的是内存消耗

现在内存比以前便宜,大家更追求时间的优化了。

此心光明,亦复何言。-- 烟沙九洲

相关推荐
身如柳絮随风扬25 分钟前
Java中的CAS机制详解
java·开发语言
-dzk-2 小时前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅2 小时前
hot100 78.子集
java·算法
Jasmine_llq2 小时前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪2 小时前
快速进制转换
笔记·算法
m0_706653232 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你913 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_423233903 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder1233 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_715575343 小时前
分布式任务调度系统
开发语言·c++·算法