[英]How do I use a “wrapper function” to call a recursive function without parameters n amount of times?
因此,对于家庭作业,我们必须对黄金分割率(n +(1 /(n + 1 /(.....))进行部分定义,但是我们需要递归地进行。好吧,这不是我可以解决的问题这样做....但是我们需要调用此递归函数1000次,并且不能使用参数函数。教授说将其限制为有限数量的调用,我们可以使用包装器函数,但是我从未听说过类,不知道从哪里开始包装函数?有人可以帮帮我吗?
如果您能告诉我如何做而不给我发送部分分数本身的解决方案,请问我在这堂课上做得不好,想自己学习。 我只需要包装功能方面的帮助。 谢谢!
“包装功能”是包装另一个功能的功能。 本质上,这是另一个调用实际函数的函数。
作为一个简单且无关的示例,请考虑要获得x
和10
的最大值。 您可以像value = std::max(x, 10)
一样直接调用std::max
,但是您不想一直传递10
的值,因此可以使用包装函数:
int max10(int x)
{
return std::max(x, 10);
}
函数max10
是包装函数。
对于您的问题,可能的解决方案是不使实际函数递归,而使包装器函数递归。 包装函数将使用一个参数n
,这是它应该进行的递归次数。 如果n
大于零,则调用实际函数,然后使用参数n - 1
递归调用包装函数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.