【C++】递归方法解决问题汇总(1)

本文探讨了C++中的递归概念,通过阶乘算法的实现来解释递归调用的过程。此外,还以输入输出字符串为例,详细分析了递归调用时内存空间的变化及程序执行流程,帮助理解递归如何在遇到换行符时反转输出字符。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、递归:函数的嵌套调用

我们知道,函数不能嵌套定义,但是可以嵌套调用。嵌套的层数无限制:
在这里插入图片描述
以编程实现阶乘算法为例:
在这里插入图片描述
在方法fact的定义中,又不断地调用自身以实现阶乘。事实上,这一种递归调用和普通调用没有区别。fact函数中这个被递归调用的fact函数可以理解为只是另外一个函数,而这个函数恰好是原函数的拷贝。

在这里插入图片描述
二、递归的过程

在学习C++函数的时候我们知道,在main函数里调用子函数,相当于在内存开辟了一块临时空间。当子函数执行完毕时,这块临时空间将被释放,程序执行的流程回到从调用结束的地方继续往下执行。这一点与单片机里的中断机制有些类似。因此,在编写递归的流程时要特别注意。以下面的输入输出字符串的程序为例子:
在这里插入图片描述
编译并执行这段程序。当用户在键盘输入 abc并回车确认 ,程序的输出是什么呢?
答案是一个回车换行符&#x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值