递归的理解

递归
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。

你可能感兴趣的:(递归)