递归的理解
递归 理解
2023-09-27 14:24:31 时间
递归
1.阶乘f(n) = n!
2.公式
f(0) = 1; f(n) = f(n-1)*n (n>=1)
3.代码
对应的程序为
#include <conio.h> #include<stdio.h> #include<string.h> int f(int n) { return n == 0?1:f(n-1)*n; } int main(){ printf("%d\n",f(3)); getch(); return 0; }
自己调用自己就是递归,但是要有一个出口,让程序走出递归。
在C语言中,调用自己和调用其他函数并没有任何本质区别,都是建立新栈帧。
4.比喻
皇帝(拥有main函数的栈帧):大臣,你给我算一下f(3)。
大臣(拥有f(3)的栈帧):知府,你给我算一下f(2)。
知府(拥有f(2)的栈帧):县令,你给我算一下f(1)。
县令(拥有f(1)的栈帧):师爷,你给我算一下f(0)。
师爷(拥有f(0)的栈帧):回老爷,f(0)=1。
县令:会知府大人,f(1)=1。
知府:回大人,f(2)=2。
大臣:回皇上 ,f(3)= 6。
相关文章
- 【Java】————二叉树的前中后序遍历(递归和迭代)
- 递归删除指定目录下的 .git 文件
- 树的非递归遍历
- 批处理清理VS工程目录(递归删除Debug, Release, ipch目录及*.sdf文件)
- hibernate无限递归问题
- 【Python 基础】求n的阶乘(递归法) || 动态规划 求 n项斐波那契数列(前n项) || 递归法 求 “斐波那契数列” 的 第n项
- LeetCode_回溯_递归_困难_37.解数独
- 递归的应用
- 递归求和生成区间随机数并排序理解
- mysql巧妙化解递归查询树形数据 | 纯sql
- Python3在指定路径下递归定位文件中出现的字符串
- 递归实现的三种枚举
- mariadb 10.2/mysql 8.0实现递归