解锁即可观看《物联网/嵌入式工程师》完整课程视频

物联网/嵌入式工程师

面向零基础保姆式教学+简历指导+1V1模拟面试+3次内推,助力轻松就业!

【第0周】物联网/嵌入式工程师就业班开学典礼
【第1周】嵌入式开发基石-计算机基础与C语言
【第2周】C语言进阶-编程思想
【第3周】C语言高级进阶
【第4周】C语言项目实战与《阶段笔试》
【第5周】数据结构-线性结构
【第6周】数据结构-非线性结构
【第7周】排序与复杂度
【第8周】数据结构项目实战
【第9周】Shell编程和Makefile工程管理
【第10周】Linux文件IO和标准IO
【第11周】Linux下文件操作项目实践与阶段评测
【第12周】Linux 多进程、多线程、IO模型
【第13周】Linux 项目实战-实现并发服务器模型与企业笔试
【第14周】网络基础和UDP Socket编程
【第15周】TCP Socket编程和WireShark抓包分析
【第16周】网络编程项目实战-网络视频监控与企业笔试
【第17周】从C到C++
【第18周】软件设计模式与C++11新特性
【第19周】项目实战-C++语言实现五子棋游戏与企业笔试
【第20周】嵌入式产品人机交互必备-QT框架
【第21周】项目实战-QT开发音乐播放器
【第22周】智能硬件开发-ARM核介绍和基础外设
【第23周】智能硬件开发-单片机常用外设
【第24周】stm32芯片-智能硬件项目实战与企业笔试
【第25周】大厂必备- linux内核与文件系统移植
【第26周】嵌入式开发-系统移植-bootloader、yocto
【第27周】嵌入式底层核心技能-Linux设备驱动初级
【第28周】嵌入式底层核心技能-Linux设备驱动中级
【第29周】嵌入式底层核心技能-Linux设备驱动高级1
【第30周】嵌入式底层核心技能-Linux设备驱动高级2
【第31周】智能家居项目实战之Linux智能网关端开发
【第32周】智能家居项目实战之STM32单片机设备端开发
【第33周】智能家居项目实战之Qt用户APP端开发
【第34周】嵌入式人工智能必备-Python
【第35周】物联网/嵌入式项目答辩和就业指导
【第36周】独立开发阶段-三大热门领域项目
章节
问答
课签
笔记
评论
占位
占位

我调我自己:函数的递归调用

在 C++ 中,可以在一个函数中调用另外一个函数,那么,函数可以自己调用自己吗? 例如:
void func()
{
    func();
}
C++ 本身其实并不禁止我们这样去做,并且还给这种调用方式起了一个名字,叫做递归调用。
 
执行上述的代码,发现程序被卡住了,好像永远不会执行完。仔细看一下这个程序,就会发现其实程序陷入到了一个无限的自我循环当中,而且这种情况比一个死循环还要糟糕。因为每一次函数的调用都会导致在栈上分配新的空间,而因为函数不会退出,所以栈空间会被一直分配下去,直到栈空间被用完,被操作系统杀死。
 
所以,如果要使用这种自己调用自己的方式,就需要满足一定的条件。已经有前人为我们总结出了递归调用的三要素,如下:
 
1. 递归的终止条件是什么?
这是非常重要的,在递归中,我们必须要设计好这一点,那就是递归什么时候停止。否则就会像前面的例子一样,直接爆栈。
 
2. 递归被分解后最基本操作是什么?
递归非常适合层级调用关系,每一层都执行相同的操作,这个要素,就是要提取出递归最核心的要素。
 
3. 递归调用传递的参数
这里传递的参数其实除了参数列表,还包括返回值。参数列表表示给下一层调用需要传递什么,返回值表示上一层调用需要返回什么。
接下来利用递归来求一个数的阶乘,首先来分析一下问题,假如要求计算 5 的阶乘,实际上是在进行以下算式:
 
我们可以将其分解成递归,如下:
 
可见,每一次递归的核心操作就是n = n * (n - 1)
而终止条件就是n == 1
由此,我们可以写出以下递归函数
int fact(int n)
{
    if(n==1) {
        return 1;
    }
    else {
        return n * fact(n-1);
    }
}

int main(int argc,char **argv)
{
    int x = 5;
    int res = fact(x);
    printf("%d\n",res);

    return 0;
}
利用递归的特性,可以很简单得处理一些利用循环特别复杂的问题,例如,遍历文件夹,遍历二叉树等。灵活使用递归,将带来极大的技术提升。

任务

?不会了怎么办
||

提问题

写笔记

公开笔记
提交
||

请验证,完成请求

由于请求次数过多,请先验证,完成再次请求

加群二维码

打开微信扫码自动绑定

您还未绑定服务号

绑定后可得到

  • · 粉丝专属优惠福利
  • · 大咖直播交流干货
  • · 课程更新,问题答复提醒
  • · 账号支付安全提醒

收藏课程后,能更快找到我哦~

使用 Ctrl+D 可将课程添加到书签

邀请您关注公众号
关注后,及时获悉本课程动态

举报

0/150
提交
取消
全部 精华 我要发布
全部 我要发布
最热 最新
只看我的

手记推荐

更多

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?