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