当前位置:首页 » 编程语言 » c语言递归调用

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;
};
};

这样在结构体内定义结构体,是可以的。

热点内容
ng算法 发布:2025-02-27 10:18:18 浏览:671
android判断文件夹是否存在 发布:2025-02-27 10:18:16 浏览:816
万能云解压 发布:2025-02-27 10:17:42 浏览:646
qq空间不允许访问 发布:2025-02-27 10:06:56 浏览:459
混合推荐算法 发布:2025-02-27 09:40:07 浏览:176
ipad2存储器 发布:2025-02-27 09:35:17 浏览:428
数控编程及工艺分析 发布:2025-02-27 09:31:31 浏览:371
如何共享加密狗 发布:2025-02-27 09:24:07 浏览:300
访问外部存储器 发布:2025-02-27 09:19:12 浏览:677
解压泥声音 发布:2025-02-27 09:19:12 浏览:500