【发布时间】:2020-09-26 15:15:38
【问题描述】:
我想以尽可能多的方式解决塔漏斗问题,并计算每种方式的时间复杂度(仅供自我练习)。 解决方案之一是这样的:
def is_hopable(arr):
if len(arr) < 1 or arr[0] == 0:
return False
if arr[0] >= len(arr):
return True
res = False
for i in range(1,arr[0]+1):
res = res or is_hopable(arr[i:]) # This line
return res
我知道递归时间复杂度计算的一般概念,但我无法分析注释行(在 for 循环内)。通常我用T(n) = C + T(that line)计算时间复杂度,然后用一个通用表达式(例如T(n-k))来减少它,直到我达到基本情况并且可以用n表示k,但是那个for循环的时间复杂度是多少?
【问题讨论】:
标签: python time-complexity big-o