首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >这些嵌套循环的大O

这些嵌套循环的大O
EN

Stack Overflow用户
提问于 2014-10-26 03:06:17
回答 1查看 1.6K关注 0票数 3

我对“大O”领域很陌生,所以请容忍我在这里。我一直在尽我所能地寻找它,但我仍然需要大量的工作才能完全理解它。

我在练习中遇到了这些嵌套的for循环,没有任何解决方案,它们看起来很复杂。因此,任何帮助都将不胜感激。

1)

代码语言:javascript
复制
int sum=0;
for(int i=0; i < n^2; i++) { // n+1
    for(int j = n-1; j >= n-1-i; j–-) { // n(n+1)/2 ?
        sum = i+j; // n(n+1)/2 ?
        System.out.println(sum); // n(n+1)/2 ?
    }
}

大O=?

2)

代码语言:javascript
复制
int sum=0;
for(int i=1; i <= 2^n; i=i*2) { // log(n)
    for(int j=0; j <= log(i); j++) { // log(n(n+1)/2) ?
        sum = i+j; // log(n(n+1)/2) ?
        System.out.println(sum); // log(n(n+1)/2) ?
    }
}

大O=?

3)

代码语言:javascript
复制
int sum = 0; int k = 23;
for(int i=k; i <= 2^(n−k); i=i*2) { // log(n)
    for(int j=2^(i−k); j < 2^(i+k); j=j*2) { // log(log(n)) ?
        sum = i+j; // log(log(n)) ?
        System.out.println(sum); // log(log(n)) ?
    }
}

大O=?

4)

代码语言:javascript
复制
int sum=0;
for(int i=2n; i>=1; i=i/2) {
    for(int j=i; j>=1; j=j/2) {
        sum = i+j;
        System.out.println(sum);
    }
}

大O=?

编辑:

  • 更正#4。抱歉搞砸了。
  • 原木的底座是2。
  • ^在这里的意思是“到电源”,而不是xor。
EN

回答 1

Stack Overflow用户

发布于 2014-10-28 21:02:36

使用Sigma符号系统地为您的迭代算法找到解决方案:

在下面的日志中使用基2:

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

https://stackoverflow.com/questions/26569408

复制
相关文章

相似问题

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