c语言递归调用
发布时间: 2025-02-27 07:32:50
Ⅰ c语言函数的递归调用
递归必须满足两个条件:1.初始条件;2.递归函数.举个例子,求阶乘:有f(1)=1;f(n)=n*f(n-1)(n≥2)现在你可以实现如下:long func(int n)//定义函数
{
long f,s=0;
if(n==1)f=1;
else
{
f=func(n-1)*n; //这里就是一个递归的过程,自身调用自身
s=s+f;
}
return s;
} 假设你现在是求3!执行过程就是:f(3)=f(2)*3;然后调用自身:f(2)=f(1)*2;在调用遇到初始条件:f(1)=1;则f(3)=1*2*3=6
Ⅱ 为什么“C语言既可以嵌套定义又可以递归调用”是错的
C语言可以递归调用,但是(函数)不能嵌套定义。
例如:
intfact(intn)
{
if(n==0)
return0;
else
returnn*fact(n-1);
}
图中的递归调用是允许的。
而:
voidfoo()
{
voidbar()
{
//Somecode
}
}
这样在函数内定义函数是不允许的。
不过结构体是可以嵌套定义的,例如:
structtest{
inta;
structdemo{
charb;
};
};
这样在结构体内定义结构体,是可以的。
热点内容