算法中的增长率(Rate of Growth)是什么意思?

一个函数或算法的代码块花费的时间随输入增长的速率称为增长率。

假设你去买一辆小车和一辆自行车。如果你朋友刚好看到,问你在买什么,我们一般都会说:买小车。因为买小车比买自行车花费高多了。

【总花费=小车的花费+自行车的花费】

【总花费≈小车的花费(近似)】

对于上面的例子,我们用一个函数来表示买车的花费,这个函数忽略低阶指数的项(相对于高阶项,他们的对函数结果的影响很小)。下面这个例子中n4 , 2n2, 100n, 和 500 分别是某个函数对应不同输入的花费,可以把它近似到n4,因为它的增长率最高。

【n4 + 2n2 + 100n + 500n ≈ n4

下面是一些我们在程序设计过程中经常会遇到的增长率:

Time ComplexityNameExample
1ConstantAdding an element to the front of a linked list
log nLogarithmicFinding an element in a sorted array
nLinearFinding an element in a unsorted array
nlog nLinear LogarithmicSorting n items by ‘Divide and Conquer’
n2QuadraticShortest path between 2 nodes in a graph
n3CubicMatrix Multiplication
2nExponentialThe Towers of Hanoi problem

转载于:https://www.cnblogs.com/programnote/p/4689609.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值