C语言|函数的递归调用

函数的递归调用 (逐层分解,逐层合并)

自己调用自己,必须要知道什么时候停止调用,不然会造成电脑死机。

【知识点】

1 函数调用是通过栈实现的。

多个函数嵌套调用时,会按照先调用后返回的原则进行返回。

2 函数递归必须满足的两个条件:

i-要有递归公式;

对问题的分解,把大问题拆解成最小问题。

ii-要有终止条件。

得到最小事件的解,让递归停下来。

3-递归的优缺点

递归的优点:简化程序设计,结构简洁清晰,容易编程,可读性强,容易理解。

递归能把复杂问题,分解为更简单的步骤,反应出问题的本质。

递归的缺点:速度慢,运行效率低,对存储空间的占用比较多。

【代码分析】

1 自定义Function函数,在程序开头放函数声明,主函数调用Function函数。

2 main()函数,定义变量num,通过键盘输入数字,直接调用Function()函数。

3 Function()函数,用if语句判断num大小,Function(num-1); 实现递归调用。

【程序代码】

include <stdio.h>

void Function(int num); // 函数声明

int main(void)

{

int num;

printf("想输出几个不愧是小新少爷!:");

scanf("%d", &num);

Function(num);

return 0;

}

void Function(int num)

{

if(num>0)

{

printf("不愧是小新少爷!\n");

Function(num-1);

}

else

{

return ;

}

}

相关推荐
LDR00614 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术14 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园14 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob14 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享14 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.14 天前
C语言--day30
c语言·开发语言
玖玥拾14 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
何以解忧,唯有..14 天前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
謓泽14 天前
C语言不是语法,是通往机器的地图。
c语言·开发语言
云水一下14 天前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php