在C#中实现部分递归函数

SHM*_*SHM 2 c# recursion

我在如何实现部分递归函数方面遇到了麻烦(尽管至少在我看来)。

对于任何给定的p任意值maxsteps= 100,计算L

在此处输入图片说明

Mur*_*nik 7

您可以将maxsteps传递给递归函数,并在每一步中减去1,直到达到0,这是结束条件:

public double L(double p, int maxSteps)
{
    if (maxSteps == 0)
    {
        return 1 / (p + 1);
    }
    return 1 / (p + L(p, maxSteps - 1));
}
Run Code Online (Sandbox Code Playgroud)