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

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

热点内容
安卓在哪里可以创建id 发布:2025-09-24 16:30:36 浏览:317
gvim编译c 发布:2025-09-24 16:20:06 浏览:485
如何在手机上进行反编译 发布:2025-09-24 15:48:18 浏览:667
java对象for循环 发布:2025-09-24 15:34:43 浏览:688
服务器如何配置ipv6 发布:2025-09-24 15:07:51 浏览:689
cd文件反编译 发布:2025-09-24 14:56:29 浏览:892
芳村万科海上传奇 发布:2025-09-24 14:19:22 浏览:519
前台加密后台解密 发布:2025-09-24 14:10:29 浏览:92
什么id密码可以下载安卓 发布:2025-09-24 13:36:54 浏览:627
win7如何登陆ftp 发布:2025-09-24 13:01:29 浏览:177