C++算法第一篇:递归

目录

递归定义

递归三要素

递归定义

        递归指函数自己调用自身,它在计算机内部创建了一个栈。

递归三要素

1.终止条件  :一个递归如果没有终止函数,就会陷入死循环那么系统分配的栈空间将会溢出

2.函数的返回值  :确定递归过程中需要处理的参数,明确每次递归的返回值进而确定递归函数的返回类型

3.递归的逻辑  :就是递归执行的内容

递归的运行逻辑

递归是一种栈结构,栈是先进后出的数据结构,例如阶乘程序

# include<iostream>
using namespace std;

int fact(int n) {
    if (n == 1) {
        return 1; 
    } else {
        return n * fact(n - 1); 
    }
}
int main()
{
    int i;
    cin>>i;
    cout<<fact(i);
    return 0;
}

假设i=4那么它的运行过程是什么?

fact(4)=fact(3)*4=fact(2)*3*4=fact(1)*2*3*4=4!

在计算机内部是这样的

递归实例:斐波那契数列

递归逻辑:上一项+上上项

fbnq(m-1)+fbnq(m-2)

递归返回:斐波那契数列第n项

递归终止条件:m<=2

#include <iostream>
using namespace std;
int fbnq(int m)
{
	if(m<=2) return 1;
	return fbnq(m-1)+fbnq(m-2);
}
int main()
{
	int m;
	cin>>m;
	cout<<fbnq(m);
}

这就是斐波那契数列的完整代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值