首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >N log n是O(n)?

N log n是O(n)?
EN

Stack Overflow用户
提问于 2011-10-20 11:15:35
回答 2查看 76.5K关注 0票数 23

我正在尝试解决这个递归问题

T(n) =3T(n/2)+n lg n .

因为n lg n是O(n^2),所以我已经得到了它属于主定理情况2的解。

但在参考了解决方案手册后,我注意到他们有这样的解决方案

解是:当e在0和0.58之间时,n lg n=O(n^(lg3- e))

这意味着n lg n是O(n)。是这样的吗?我是不是漏掉了什么?

nlgn不是O(n^2)吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-10-20 11:28:18

这会更好地解释事情

票数 90
EN

Stack Overflow用户

发布于 2011-10-20 11:22:20

n*log(n)不是O(n^2)。它被称为准线性,它的增长速度比O(n^2)慢得多。事实上,n*log(n)小于多项式。

换句话说:

代码语言:javascript
复制
O(n*log(n)) < O(n^k)

where k > 1

在您的示例中:

代码语言:javascript
复制
3*T(2n) -> O(n^1.585)

由于O(n^1.585)是多项式的,并且在O(n*log(n))中占主导地位,因此后一项下降,所以最终的复杂度就是O(n^1.585)

票数 15
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7830727

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档