// 这个是求阶乘的递归(很经典的,很多书中都会有的!)
#include "stdio.h"
int fun(int n)
{
if (n==0 || n==1)
return 1;
else
return n*fun(n-1);
}
main()
{
int n;
printf("请输入求阶乘的数字:");
scanf("%d", &n);
printf("the n! is %d \n",fun(n));
}
程序调用自身的编程技巧称为递归 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。一般来说,递归需要有边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。