首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >复杂度是O(log(n) + log(n/2) + log(n/4) + log(n/8) + ... + log(2)) = O(log(n))?

复杂度是O(log(n) + log(n/2) + log(n/4) + log(n/8) + ... + log(2)) = O(log(n))?
EN

Stack Overflow用户
提问于 2017-05-29 03:17:59
回答 1查看 8K关注 0票数 3

作为家庭作业,我被要求用O(log(n))编写一个算法,我可以计算出我编写的算法的复杂度为O(log(n) + log(n/2) + log(n/4) + log(n/8) + ... + log(2))。

我认为它相当于O(n),因为它大致是log(n)*O(log(n)) = O(n)。但我对此并不确定。我知道家庭作业问题在这里是不受欢迎的,但我真的不知道另一种方法来找出它的复杂性。谷歌搜索对我没什么帮助。

指定:N中的n和n= pow(2,c),N中的c

EN

回答 1

Stack Overflow用户

发布于 2017-05-29 03:20:08

从一些基本的算术开始:

代码语言:javascript
复制
O(log n/2) = O( (log n) + log(1/2))

可以忽略该常量。因此:

代码语言:javascript
复制
O(log n / 2) = O(log n)

所以,你添加了一堆O(log )的东西。多少?好吧,关于log(n)值。所以,这意味着算法是:

代码语言:javascript
复制
O( (log n)^2)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44231116

复制
相关文章

相似问题

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