算法的效率度量——时间复杂度

算法的效率度量

算法的效率度量:

  • 时间复杂度
  • 空间复杂度

时间复杂度

如何评估算法的时间开销?

------让算法先运行,事后统计运行时间?

存在问题:

  • 和机器性能有关。如:超级计算机VS单片机
  • 和编程语言有关,越高级的语言执行效率越低
  • 和编译程序产生的机器指令质量有关
  • 有些算法是不能够时候再统计时间的。

算法的时间复杂度: 事前预估算法时间开销T(n) 与问题规模n的关系(T 表示 "time")。可以只考虑阶数最高的部分。

加法规则。多项相加,只保留最高阶的项,且系数变为1

乘法规则 。多项相乘,都保留

O(1) < O(log~2~n) < O(n) < O(nlog~2~n) < O(n^2^) < O(n^3^) < O(2^n^) < O(n!) < O(n^n^)

(常对幂指阶)

  • 顺序执行的代码只会影响常数项,可以忽略。
  • 只需要挑循环中的一个基本操作分析它的执行次数与n的关系
  • 如果有多层嵌套循环,只需要考虑最深层循环的次数与n的关系
相关推荐
北顾南栀倾寒2 小时前
[算法笔记]cin和getline的并用、如何区分两个数据对、C++中std::tuple类
笔记·算法
一只大侠4 小时前
牛客周赛A:84:JAVA
算法
豆豆酱4 小时前
Informer方法论详解
算法
槐月初叁4 小时前
多模态推荐系统指标总结
算法
迪小莫学AI4 小时前
LeetCode 2588: 统计美丽子数组数目
算法·leetcode·职场和发展
昂子的博客4 小时前
热门面试题第十天|Leetcode150. 逆波兰表达式求值 239. 滑动窗口最大值 347.前 K 个高频元素
算法
卑微小文5 小时前
2025国内网络反爬新高度:代理IP智能轮换算法揭秘
后端·算法·架构
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧7 小时前
C语言_数据结构总结7:顺序队列(循环队列)
c语言·开发语言·数据结构·算法·visualstudio·visual studio
LIUJH12337 小时前
数据结构——单调栈
开发语言·数据结构·c++·算法
2301_807449207 小时前
字符串相乘——力扣
java·算法·leetcode