为了账号安全,请及时绑定邮箱和手机立即绑定

计算以下代码的时间复杂度

计算以下代码的时间复杂度

慕仙森 2022-10-11 10:00:47
有人可以帮忙找出以下代码的复杂性吗?def mystery(n):    sum = 0    if n % 2 == 0:        for i in range(len(n + 10000)):             sum += 1    elif n % 3 == 0:        i, j = 0, 0        while i <= n:            while j <= n:                sum += j - 1                j += 1            i += 1    else:        sum = n**3以下代码的时间复杂度是否为 O(n^2),因为在最坏的情况下,elif 语句将被执行,因此外部 while 循环将执行 n 次,而嵌套的 while 循环将仅执行n次因为我们从不重置 j?因此,我们将有 O(n^2 + n) 并且因为前导项是 n^2,所以复杂度将是 O(n^2)?
查看完整描述

1 回答

?
子衿沉夜

TA贡献1828条经验 获得超3个赞

在该elif部分:

  • i=0 时,while j <= n:循环为 O(n)。

  • i>0 时,j=n+1,所以while j <= n:循环是 O(1)。

所以这个elif部分是 O(n) + O(n*1) = O(n+n) = O(n)。


查看完整回答
反对 回复 2022-10-11
  • 1 回答
  • 0 关注
  • 103 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信