【C++练习系列】菲普奈斯数列的递归函数算法(小白做法,不懂递归也没关系)

(一)例题

题目:Fibonacci数列的定义是: F_0=0,F_1=1,F_n=F_(n-1)+F_(n-2) (n≥2,n∈N)。请用递归函数计算Fibonacci数列第n项的值

(二)详尽解析

先上代码:

#include <iostream>
using namespace std;

int Fib(int n)
{
    int i;
    if (n == 0)
        return i = 0;
    if (n == 1)
        return i = 1;
    else
    {
        i = Fib(n - 1) + Fib(n - 2);
        return i;
    }
}

int main()
{
    int n;
    cin >> n;
    cout << Fib(n) << endl;
    return 0;
}

递归算法我也发了有:选择排序的递归算法汉诺塔的递归算法。其基本套路是一样的,甚至连结构都差不多。

那如果我就是不会递归算法的原理,那我还能写出来吗?
写了这么多的题后,总结的规律如下:

第一:你必须知道头几个的值是什么。用 if 语句写第一个数,把结果写下来。就像这样:

if (n == 0)
        return i = 0;
    if (n == 1)
        return i = 1;

第二:在 else 里面写那条公式。就像这样:

else
    {
        i = Fib(n - 1) + Fib(n - 2);
        return i;
    }

最后:在main( )函数中引用函数即可。

最后我想说的是,这是我的【C++练习系列】的第六篇文章,喜欢的话希望可以点一下赞,并关注我的前面五篇文章,ok,再见啦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

在下_诸葛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值