gpt4 book ai didi

c++ - 将此递归函数转换为迭代函数

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:06:15 28 4
gpt4 key购买 nike

如何将此递归函数转换为迭代函数?

#include <cmath>

int M(int H, int T){
if (H == 0) return T;
if (H + 1 >= T) return pow(2, T) - 1;
return M(H - 1, T - 1) + M(H, T - 1) + 1;
}

这是一个 3 行代码,但我很难将其转换为迭代函数。因为它有2个变量。而且我对 Stacks 一无所知,所以我无法转换它。

我这样做的目的是提高函数的速度。这个功能太慢了。我想使用 map 来加快速度,但我有 3 个变量 MHT,所以我不能不使用 map

最佳答案

您可以使用动态规划 - 当 H == 0 和 T == 0 计算 M 并迭代它们时,从下往上开始。这是一个link解释如何对斐波那契数执行此操作,这与您的问题非常相似。

关于c++ - 将此递归函数转换为迭代函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21572631/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com