【发布时间】:2021-02-28 00:12:12
【问题描述】:
第一个函数:
def f1(n):
if n == 1:
return 1
return f(f(n-1))
第二个功能:
def f2(n):
if n == 1:
return 1
return 1 + f(f(n-1))
现在我可以看到为什么两个函数的空间复杂度都是O(n),因为递归深度等于n。
但是关于时间复杂度,我无法像以前使用普通递归方程那样计算它,可以说我们在第一个函数中使用了f(n-1) 而不是f(f(n-1))。那么它将是T(n) = 1 + T(n-1) = 2 + T(n-2)=... = n 所以O(n),我可以直观地理解它对于f1 可能保持不变,因为所有返回都是1 所以我可能有2n 迭代这是O(n) 但我不知道如何正式处理。
对于f2,我不知道如何达到时间复杂度,直觉在这里失败了,我非常感谢在如何分析这些递归调用方面提供任何帮助。
最终答案是:f1: Time Complexity: O(n), Space Complexity: O(n)。
f2: Time complexity: O(2^n), Space complexity: O(n).
【问题讨论】:
标签: python recursion time-complexity