C++ 中的递归函数实现斐波那契数列
这篇文章将解释如何在 C++ 中使用递归函数实现斐波那契数列。 为此,我们将首先简要介绍递归函数。
C++ 中的递归函数
递归函数在其自身内部调用自身,使用此概念称为递归。 这个概念在很多方面都很有用,一些功能可以只使用递归来实现。
上图展示了递归的概念。 在main函数中,调用了一个函数recurse,在那个函数中,又调用了recurse。
这将创建一个递归调用,程序将继续在此函数中迭代,直到满足某些条件。 通常,递归函数中使用 if...else 结构,一条路径进行递归调用,另一条路径退出函数; 否则会出现无限递归。
递归从函数内部多次重复调用函数。 递归条件再次调用该函数,直到满足基本情况。
基本情况包含在函数内部,只要满足基本情况的条件,它就会终止执行。
代码:
void recursiveFun (int x )
{
if (x == 0)
return;
x = x-1;
recursiveFun(x);
}
上面的函数一旦用参数 x 调用,将递归地用 x 的减少值调用自身(即 [x-1, x-2, ..., x-(x-1)])直到 x 变为零。 当遇到值为零的 x 时,程序将停止生成新的递归调用并开始从下到上返回值(如果有的话)。
虽然递归可以用来解决几乎所有的问题,但在某些特定的情况下它确实是有益的。 它通常用于处理遵循层次结构模式的难题和问题; 它通过解决较小的子问题来解决主要问题。
递归类型
直接递归和间接递归是递归的两种类型。
直接递归
递归函数通过直接递归直接在自己的函数体中调用自己。
void recursion ()
{
....
recursion();
}
在代码中,我们可以看到函数在自己的函数体或括号中调用自己。
间接递归
在间接递归中,该函数在任何其他函数的主体中间接调用。
void func1()
{
...
func2();
}
void func2()
{
...
func1();
}
斐波那契数列
斐波那契数列是一组整数,其中每个连续的数字都是前两个数字的总和。 前两个数 0 和 1,第三个数是前两个数相加的结果。
斐波那契数列的计算公式为:
例如 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, ...
我们可以看到第三个元素1是0+1的和。 同样,第四个数字 2 是前面数字的总和 **(1+1=2)**。
因此我们可以预测该系列的下一个元素是 21+34 = 55。
C++ 中的斐波那契数列
为了实现斐波那契数列,我们可以实现一个递归函数,它可以接受一个数字作为输入,并打印出该数量的斐波那契数列。 例如,如果用户输入 8,我们将打印该系列的 8 个数字。
代码:
#include <iostream>
using namespace std;
int fibonacci (int num)
{
if (num <= 1)
return num;
return fibonacci(num-1) + fibonacci (num-2);
}
int main()
{
int num;
cout<<"Enter a number: ";
cin>> num;
for (int a =0; a < num; a++)
{
cout<<fibonacci(a)<<" ";
}
return 0;
}
在主函数中,我们提示用户输入一个数字。 之后,我们迭代了一个从 0 到输入数字 num 的循环,并将迭代器变量 a 传递给斐波那契函数。
该循环将迭代 num 次用户输入的数字。 在 Fibonacci 函数中,我们有一个 if 条件来检查数字是否小于 1,然后它会返回该数字。
否则,它将为 num-1 和 num-2 调用斐波那契函数,因为该系列的每个下一个数字都是通过对前两个数字(即 n-1 和 n-2)求和来计算的。
输出:
用户输入了数字 9,因此打印出包含 9 个值的斐波那契数列。
相关文章
在 C++ 中通过掷骰子生成随机值
发布时间:2023/04/09 浏览次数:169 分类:C++
-
本文解释了如何使用时间因子方法和模拟 C++ 中的掷骰子的任意数方法生成随机数。了解它是如何工作的以及它包含哪些缺点。提供了一个 C++ 程序来演示伪数生成器。
在 C++ 中使用模板的链表
发布时间:2023/04/09 浏览次数:158 分类:C++
-
本文解释了使用模板在 C++ 中创建链表所涉及的各个步骤。工作程序演示了一个链表,该链表使用模板来避免在创建新变量时声明数据类型的需要。
在 C++ 中添加定时延迟
发布时间:2023/04/09 浏览次数:142 分类:C++
-
本教程将为你提供有关在 C++ 程序中添加定时延迟的简要指南。这可以使用 C++ 库为我们提供的一些函数以多种方式完成。
在 C++ 中创建查找表
发布时间:2023/04/09 浏览次数:155 分类:C++
-
本文重点介绍如何创建查找表及其在不同场景中的用途。提供了三个代码示例以使理解更容易,并附有代码片段以详细了解代码。
如何在 C++ 中把字符串转换为小写
发布时间:2023/04/09 浏览次数:63 分类:C++
-
介绍了如何将 C++ std::string 转换为小写的方法。当我们在考虑 C++ 中的字符串转换方法时,首先要问自己的是我的输入字符串有什么样的编码
如何在 C++ 中确定一个字符串是否是数字
发布时间:2023/04/09 浏览次数:163 分类:C++
-
本文介绍了如何检查给定的 C++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。
如何在 c++ 中查找字符串中的子字符串
发布时间:2023/04/09 浏览次数:65 分类:C++
-
本文介绍了在 C++ 中检查一个字符串是否包含子字符串的多种方法。使用 find 方法在 C++ 中查找字符串中的子字符串
如何在 C++ 中把字符串转换为 Char 数组
发布时间:2023/04/09 浏览次数:107 分类:C++
-
本文介绍了在 C++ 中把字符串转换为 char 数组的多种方法。使用 std::basic_string::c_str 方法将字符串转换为 char 数组