首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >算法复杂度循环

算法复杂度循环
EN

Stack Overflow用户
提问于 2014-04-02 19:47:44
回答 2查看 120关注 0票数 0

三重嵌套循环的时间复杂度

代码语言:javascript
复制
for(int i=0; i<n; i++)
    for(int j=i+1; j<n; j++)
        for(int k=j+1; k<n; k++)

我想知道时间复杂性的正确解决方案。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-11 14:33:52

确定算法增长顺序的正式解决方案:

票数 2
EN

Stack Overflow用户

发布于 2014-04-10 13:15:52

第一个猜测:依赖于n的三个循环,所以它应该是O(n³)

如果你试图计算精确的复杂性,你必须计算它的内部,乘以它与外部循环。

内环采用O(n-k)

中间回路采用O(n-j + n-j-1 + ... + n-j-n) = O((n-j) ⋅ (n-j+1) / 2) = O((n-j)²)

外循环采用O((n-1)² + (n-2)² + ... + (n-n+1)²) = O(n³)

当然,这不是精确的,但就大-O而言,它是精确的。

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

https://stackoverflow.com/questions/22821512

复制
相关文章

相似问题

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