费波纳奇记忆化的时间复杂度?
我有记忆斐波那契代码,我无法计算出它的时间复杂度是多少:
function fibMemo(index, cache) {
cache = cache || [];
if (cache[index]) return cache[index];
else {
if (index < 3) return 1;
else {
cache[index] = fibMemo(index - 1, cache) + fibMemo(index - 2, cache);
}
}
return cache[index];
}
此函数的时间复杂度是多少?
解决方案
取决于您的意思。
假设正确完成了备忘,则"操作"的数量将是生成的数字的数量。这意味着函数运行时与您试图生成的数字数量相关。
所以它将是O(N),其中n是生成的数字的数量。
相关文章