当前位置:首页 » 编程语言 » 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;
};
};

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

热点内容
java返回this 发布:2025-10-20 08:28:16 浏览:645
制作脚本网站 发布:2025-10-20 08:17:34 浏览:936
python中的init方法 发布:2025-10-20 08:17:33 浏览:632
图案密码什么意思 发布:2025-10-20 08:16:56 浏览:821
怎么清理微信视频缓存 发布:2025-10-20 08:12:37 浏览:731
c语言编译器怎么看执行过程 发布:2025-10-20 08:00:32 浏览:1066
邮箱如何填写发信服务器 发布:2025-10-20 07:45:27 浏览:299
shell脚本入门案例 发布:2025-10-20 07:44:45 浏览:160
怎么上传照片浏览上传 发布:2025-10-20 07:44:03 浏览:852
python股票数据获取 发布:2025-10-20 07:39:44 浏览:763