C语言之函数递归

目录

1.递归是什么?

1.1递归的思想:

1.2递归的限制条件

2.递归举例

2.1 举例1:求n的阶乘

2.1.1分析和代码实现

2.2举例2:顺序打印一个整数的每一位

3.递归的弊端和迭代的引出

4.拓展学习

5.小结

halo~又与大家见面了,俗话说:“寒假肯吃苦,开春猛如虎。”各位高薪程序员们已经开始疯狂内卷了吧。今天,也给大家奉上鄙人对函数递归的一些见解,话不多说,正文开始。

1.递归是什么?

递归是学习c语言函数绕不开的一个话题,那到底什么是递归呢?

递归其实是解决问题的一种方法,在c语言中,递归就是函数自己调用自己

eg.

这是史上最简单的c语言代码(没有之一!)也是一个简单的递归程序,只不过上面的递归只是为了演示递归的基本形式,不是为了解决问题,代码也终将会陷入死递归,导致栈溢出(Stack overflow)

补充:Stack overflow也是国外的一个程序员技术问答社区,很实用,不过需要翻墙~

1.1递归的思想:

把一个大型复杂的问题层层转化为一个与原问题相似,但规模较小的子问题来求解;直到子问题不能再被拆分,递归就结束,故可以将递归的认为是大事化小的过程。

递归中,递就是递推的意思,规就是回归的意思,接下来慢慢体会~

1.2递归的限制条件

递归在书写的时候,有两个必要的条件:

1.递归存在限制条件,当满足这个条件的时候,递归便不再继续。

2.每次递归调用之后越来越接近这个限制条件。

接下来将举例说明:

2.递归举例

2.1 举例1:求n的阶乘

一个正整数的阶乘(factorial)是所以小于及等于该数的正整数的积,并且0的阶乘为1,自然数n的阶乘写为n!。

题目:计算n的阶乘(不考虑溢出),n的阶乘就是1~n的数字累计相乘。

2.1.1分析和代码实现

我们知道n的阶乘的公式:n!=n*(n-1)!

因此递归方式如下:

由此函数如下:

画图分析:

2.2举例2:顺序打印一个整数的每一位

输入一个整数m,按顺序打印整数的每一位。

比如:

输入:1234     输出:1 2 3 4

输入:1314     输出:1 3 1 4

代码实现:

画图分析:

3.递归的弊端和迭代的引出

在c语言中每一次函数使用,都需要为本次函数调用在内存的栈区,申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,or函数栈帧。

函数不返回,函数对应的栈帧空间就一直占用,所以如果函数调用中存在递归调用的话,每一次递归函数调用都会开辟属于自己的栈帧空间,直到函数递归不再继续,开始回归,才会逐层释放栈帧空间。

所以如果采用函数递归的方式完成代码,递归层次太深,就会浪费太多栈帧空间,也可能引起栈溢出的问题。

所以,如果不想使用递归就得想其他的方法,通常是迭代的方式(通常就是循环的方式)

eg.计算n的阶乘,也可以1~n的数字累计乘起来

上述代码也可完成任务,并且效率比迭代更高。

4.拓展学习

如果有感兴趣的uu们,可以去尝试一下:

1.青蛙跳台阶问题

2.汉诺塔问题

5.小结

今天的学习就到这啦~希望大家多多努力,y'q

  • 77
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 22
    评论
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值