当前位置:首页 » 编程语言 » C语言递归函数调用返回
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

C语言递归函数调用返回

发布时间: 2022-07-27 13:36:15

c语言递归函数

递归(recursion)就是子程序(或函数)直接调用自己或通过一系列调用语句间接调用自己,是一种描述问题和解决问题的基本方法。
递归通常用来解决结构自相似的问题。所谓结构自相似,是指构成原问题的子问题与原问题在结构上相似,可以用类似的方法解决。具体地,整个问题的解决,可以分为两部分:第一部分是一些特殊情况,有直接的解法;第二部分与原问题相似,但比原问题的规模小。实际上,递归是把一个不能或不好解决的大问题转化为一个或几个小问题,再把这些小问题进一步分解成更小的问题,直至每个小问题都可以直接解决。因此,递归有两个基本要素:
(1)边界条件:确定递归到何时终止,也称为递归出口。
(2)递归模式:大问题是如何分解为小问题的,也称为递归体。递归函数只有具备了这两个要素,才能在有限次计算后得出结果
汉诺塔问题:对汉诺塔问题的求解,可以通过以下3个步骤实现:
(1)将塔上的n-1个碟子借助塔C先移到塔B上;
(2)把塔A上剩下的一个碟子移到塔C上;
(3)将n-1个碟子从塔B借助塔A移到塔C上。
在递归函数中,调用函数和被调用函数是同一个函数,需要注意的是递归函数的调用层次,如果把调用递归函数的主函数称为第0层,进入函数后,首次递归调用自身称为第1层调用;从第i层递归调用自身称为第i+1层。反之,退出第i+1层调用应该返回第i层。采用图示方法描述递归函数的运行轨迹,从中可较直观地了解到各调用层次及其执行情况,具体方法如下:
(1)写出函数当前调用层执行的各语句,并用有向弧表示语句的执行次序;
(2)对函数的每个递归调用,写出对应的函数调用,从调用处画一条有向弧指向被调用函数入口,表示调用路线,从被调用函数末尾处画一条有向弧指向调用语句的下面,表示返回路线;
(3)在返回路线上标出本层调用所得的函数值。n=3时汉诺塔算法的运行轨迹如下图所示,有向弧上的数字表示递归调用和返回的执行顺序
三、递归函数的内部执行过程
一个递归函数的调用过程类似于多个函数的嵌套的调用,只不过调用函数和被调用函数是同一个函数。为了保证递归函数的正确执行,系统需设立一个工作栈。具体地说,递归调用的内部执行过程如下:
(1)运动开始时,首先为递归调用建立一个工作栈,其结构包括值参、局部变量和返回地址;
(2)每次执行递归调用之前,把递归函数的值参和局部变量的当前值以及调用后的返回地址压栈;
(3)每次递归调用结束后,将栈顶元素出栈,使相应的值参和局部变量恢复为调用前的值,然后转向返回地址指定的位置继续执行。
上述汉诺塔算法执行过程中,工作栈的变化如下图所示,其中栈元素的结构为(返回地址,n值,A值,B值,C值),返回地址对应算法中语句的行号,分图的序号对应图中递归调用和返回的序号
我可以帮助你,你先设置我最佳答案后,我网络Hii教你。

Ⅱ c语言递归函数的问题

通过分析这个代码,建立了如图的树。

1、当进去A时,num = 1;

2、接着往左进去B,num = 2;

3、往B左边及右边因为是NULL直接返回2处,再返回到1处;

4、接着往A右边C,此时num=3,这里把返回值C压入寄存器RAX,代码返回到A,但是最上层A处没有接收返回值,此时A退出,main函数从RAX取出返回值赋值给变量a。

这就是整个调用过程,这里返回值并不是最上层的返回值,是C的返回值,之所以能得到这个值是这个程序没有同步其它地方使用了RAX寄存器,它的值没有被修改。

Ⅲ c语言递归调用怎么返回第一次递归调用


讨论下:递归是利用栈来实现的。被调函数地址首先存入栈,存在栈底部红色部分,然后f(5)入栈,f(4)、f(3)、f(2)、f(1)依次入栈,由于当n=1时候,f(1)可以被求解,f(1)出栈,栈顶指针top--,依次解析f(2)、f(3)、f(4)、f(5),最后返回被调函数地址。

Ⅳ c语言函数的递归调用

递归有一个堆栈的概念,那就意味着他是一个反理解的过程:就象数学递推一样,你知道第一项,第二项,又知道通项公式,那你就可以知道任何一项。
然后你看代码:fun(0)==0,fun(1)==1;是告诉你一二项。
fun(n)==fun(n-1)+fun(n-2);是告诉你通项公式。那么,你就可以知道任何一项。你这样理解就差不多了,具体机器是怎么操作的,那很复杂的,也不需要明白!!!!

Ⅳ C语言中自定义函数中递归调用是怎样工作的

假如输入3
y=ff(n);
//第一次调用
执行else
f=ff(n-1)*n;
//f=ff2*3
ff2递归
执行else
f=ff(n-1)*n;
//f=ff1*2
ff1递归
执行else
if(n==0||n==1)
f=1;
f=1
跳过else
f=ff(n-1)*n;
//两个else并列的不再执行第二个
执行return(f);
从printf("%d!=%ld",n,y);向下执行主程序

Ⅵ 讲一下c语言中递归函数的使用方法

相当于循环,要有判断条件,传递进去的参数要变化,满足条件调用自身,不满足条件就开始一层一层返回。简单例子:
int
f(int
i){
int
sum=0;
if(i>0)
sum+=f(i-1);
return
sum;
}
main(){
int
a=10;
printf("%d",f(a));
}

Ⅶ C语言 函数返回值递归调用

int
fun(int
n)
定义函数fun
{if
(n>1)
return
n*fun(n-1);
如果n>1,函数
返回值
为n*fun(n-1)
else
return
1;
}
否则为1;
main()
主函数
{int
i,s=0;
整型i,s,其中s=0
for(i=1;i<=4;i++)
i小于等于4时,运行s+=fun(i),然后i自加
s+=fun(i);
s等于s加上函数fun的返回值
printf(''%d\n",s);
}
打印s
最后结果为s=1+2*1+3*2*1+4*3*2*1

Ⅷ C语言函数的返回值(递归)

inthehe(intn){
if(n<=1)return1;
returnn*hehe(n-1);
}

我们一点一点来看:

首先 n = 0 传入,if条件满足 返回 hehe(0) = 1

在传入 n = 1, if条件还是满足 返回 hehe(1) = 1

我们传入参数 n = 2, if 条件不满足 hehe(2) = 2 * hehe( 2 - 1 )= 2 * 1

在我们传入 n =3 , if条件不满足 hehe(3) = 3 * hehe(2) ==> 3 * 2 * 1

你继续这个步骤 ,对任何正整数n

hehe(n) = n * hehe(n-1) = n * (n-1) * ......* 1

明白了吗?!