算法分析, 时间复杂度,和BIG O,OMEGA, THETA NOTATION

本文探讨了算法分析中的时间复杂度,使用Java StopWatch测量算法执行时间,并介绍了数学模型在分析中的应用。讲解了常见增长数量级,如常数、对数、线性、平方和指数级别。同时,通过改进3Sum问题,展示了如何将三层循环优化为线性对数级别。最后,解释了大O、Omega和Theta记号在描述算法性能上的区别和重要性。
摘要由CSDN通过智能技术生成

实验方法

  1. 用Java的StopWatch数据类型,记录从创建对象到算法完成所需的时间
  2. 程序在不同的计算机上运行时间之比通常是一个常数。我们可以用幂次法则,绘制标准图像和对数图像。标准图像X轴为问题规模(N),y轴为运行时间T(N)。而对数图像中,x轴就是lg(N),y轴是lg(T(N))。对数图像会是一条直线,等价于我们对数据符合公式T(N)=aN^b的猜想。
  3. 数学模型:一个程序运行的总时间主要和两点有关:1是每行语句执行的耗时,2是每条语句的频率。算出方程表达式之后取最高次数项。

More about 数学模型在算法分析中的应用

对于大多数程序,得到算法的运行的数学模型有如下步骤

  1. 确定input size,输入模型
  2. 找内循环
  3. 根据内循环的操作确定成本模型。比如3Sum中的成本模型就是数组的访问次数(访问数组元素的次数)。
  4. 对于给定的输入,判断这些操作的执行频率。

常见的增长数量级分类

以下为常见的算法分析方程形式,与微积分中求极限常见的方程相同。

  1. 一行语句 a+b = c为常熟级别(1)
  2. 二分查找为对数级别(logN)
  3. 遍历数组为线性级别(N)
  4. 分治法,归并排序就是线性对数级别(nlogn)
  5. 双层循环是平方级别,selecti
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值