【问题标题】:Number of addition and multiplication operators in this algorithm该算法中加法和乘法运算符的数量
【发布时间】:2012-12-05 06:07:42
【问题描述】:

考虑以下算法:

i := 1
t := 0
    while i ≤ n
       t := t + i
       i := 2i

我很想知道这个算法执行了多少次加法和乘法运算;但是,我遇到了麻烦。我知道每次迭代后 i 的值加倍,但我不知道如何推广算法以给出正确数量的操作,直到 n 的值。如果有人能对这个问题有所了解,我将不胜感激。

谢谢!

【问题讨论】:

  • 每个循环包含一个加法和一个乘法,因此您只需计算循环运行的次数。
  • 我明白这一点。但是,我现在遇到了麻烦。

标签: big-o complexity-theory asymptotic-complexity


【解决方案1】:

由于i 的值在每个循环中翻倍并且i <= n

i*2^x <= n

并且最大化 x 给出循环数。因为 i = 1

2^x = n
x = floor log(n)

我们在每个循环中执行 1 次加法和 1 次乘法。我想你可以从这里拿走它:)

【讨论】:

  • 你能解释一下你是如何得到 2^x 这个词的吗?
  • 循环执行次数
  • 哦(没有双关语)!我误解了这个问题(以及你的回应)。感谢您的帮助,非常感谢:D
  • 没问题,如果我的回答不错,请勾选旁边的绿色小对号,将此问题标记为已回答
  • 一分钟后,我会的!你这个小帅哥:P
猜你喜欢
  • 2021-07-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多