递归算法
Recursion algorithm
本文关键字:递归算法 更新时间:2023-10-16
当我写一个递归程序时,即使是一个很小的程序,我也总是感到困惑。
#include <iostream>
using namespace std;
int recursion(int x)
{
if(x == 0)
return 0;
return (x + recursion(x-1)); //recursive function call should always be in the return statement?
}
int main()
{
cout<<"SUM:"<<recursion(9);
}
是否有其他方法可以使递归函数调用不在返回语句中
没有语言规则规定递归调用必须作为return
语句的一部分出现。它可以出现在方法中的任何地方(甚至可能出现在几个地方)。
int recursion(int x)
{
if (x == 0) return 0;
int rec = recursion(x-1);
return x + rec;
}
也就是说,在函数的最后进行递归调用有它的好处:这被称为"尾部递归",一个好的编译器可能能够优化尾部递归。
最后,值得一提的是,在您的特定示例中(将从0
到n
的数字相加),递归是完全没有必要的。
你当然可以用任何你喜欢的方式递归。例如,要以简单的方式计算斐波那契数列,您需要一个递归,它的分支必须非常快:
inf fib(int n)
{
//... base case
int a = fib(n - 1);
int b = fib(n - 2);
return a + b;
}
您也可以写return fib(n-2) + fib(n-1);
,但关键是在这种情况下您不能消除递归分支。
void sum(int n, int & result)
{
if (n = 0) return;
result += n;
sum(n - 1, result);
}
这种特殊情况的关键特征是递归可以完全在原地进行。一般来说,堆栈增长为(B & -; 1)n,其中n是递归深度,B是并行求值的个数。这是指数的(读:bad), 除非你有B = 1,在这种情况下,可以尝试将函数设计为尾部递归。
在进行递归时,不要考虑递归。想想:"啊,在这一点上,调用recursion()
函数"或"哦,我可以在这里重用它"是很实用的。它们是普通的函数调用,就像所有其他调用一样。
递归这个术语不必要地混淆了许多新手程序员。如果你理解了函数和函数调用,那么你已经理解了递归,只是你还不知道而已。
不需要将递归函数调用放在return语句中;你可以这样做:
int recursion(int x)
{
if(x == 0)
return 0;
int val = recursion(x-1);
return (x + rec);
}
相关文章:
- 需要为 C++ 中的以下问题设计递归算法
- 这种用于查找连续子数组中最大和的递归算法有什么优势吗?
- 运行合并排序递归算法时EXC_BAD_ACCESS错误
- 如何改进搜索二项式系数的递归算法
- 如何转换多次调用自己的递归算法?
- 如何将字符串保存在最长的常见子序列递归算法中
- 编写递归算法以从链表中删除元素.编写递归算法以将元素添加到链表中
- 指针似乎迷失在递归算法中
- 如何从递归算法返回节点
- 从递归算法到迭代算法
- 可传递值影响递归算法的渐近时间复杂性
- 我的递归算法中的问题,用于查找所有最短、唯一的路径
- 带有两个递归调用的递归算法的时间复杂性
- 这种递归算法有什么问题?
- C++递归算法中抛出异常
- 将条件递归算法转换为迭代算法
- 递归算法中的分段错误
- printbinary递归算法
- 迭代等价于递归算法
- O(n^m) 复杂度的递归算法