c语言中的函数递归调用函数
A. 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);向下执行主程序
B. C语言函数递归调用问题
函数其实没有释放内存的概念,因为函数都是在指令区,而不是通常所说的释放内存对应的数据区,不过在整个程序执行完之后指令区也是要释放的。
函数调用的大概过程如下:
1,将调用函数的上下文入栈;
2,调用被调用函数;
3,被调换函数执行;
4,调用函数上下文出栈,继续执行后继指令。
所以在函数调用过程中原调用函数是不会退出的-----即你所说的释放内存。
具体到你给的代码:
首先main中调用test,
进入test后要求读入一个char,
你输入'1'后执行case
'1'中语句,所以输出“已调用”,然后就执行test()语句,即递归调用,此时main调用的test要等新的test执行完毕才能继续执行后继的i++语句;
再次进入test之后与从main中进入时一样,如果输入的是'1'会接着递归调用test,由于你输入了5次1,所以会继续调用5次test;
在最后一个test中你输入了ESC?
所以不再走case
'1'而走default了,所以输出"222222";
switch执行完之后判断c==27满足,所以while循环退出,继续执行printf语句,由于之前的test统统没有执行过case
1里的i++语句,所以全局变量i还是0;输出i=0;
到此最后一次test执行完毕;
倒数第二次的test继续执行i++,
所以i=2了,case
1执行完毕,但由于没有写break语句,所以继续执行default
语句,输出"222222",
退出switch语句,判断c==27,
由于c是全局变量,且最后一次输入的刚好是ESC,
所以判断满足,
退出while循环,输出i=1,
到此倒数第二次test执行完毕;
与倒数第二次类似的继续执行倒数第三、倒数第四、倒数第五和最终的第一次test后继代码,也就输出如你列出的结果了。
C. c语言关于函数的递归调用问题
一般来说是自己调用自己,一般有两个分支,一个分支是调用自己,还有一个分支是结束条件如求n! int f(int n) { if(n==1) //这个是结束条件 return 1; else //这个是调用自己的分支 return n*f(n-1); } 还有一个比较复杂一点,是双向调用,也就是a函数调用b函数,b函数在调用a函数这样循环调用,其实基于这个道理,还有多个函数互相调用,不过这样的情况很少见但万变不离其宗,每个函数都有两个分支,一个是结束条件,一个是调用函数
D. c语言 函数递归调用
这个很好理解啊,你看看你输入的参数什么就可以了。
你函数的声明是void fuck ( int n ,char o, char t, char th)
第一次调用你是fuck ( n, 'A','B','C');这时,o=A,t=B,th=C,所以输入
printf ("%c %c %c\n",t,o,th);就是BAC,
然后你fuck(n-1,t,o,th);,这时o=原来的t=B,t=原来的o=A,th=C,输出
printf ("%c %c %c\n",t,o,th);就是ABC了如此类推
E. 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
F. c语言函数递归调用
我给你举个简单的例子你就明白了,你可以假设n=3
然后代入这个函数,a(3)=a(2)+5;而a(2)=a(1)+5;a(1)=1
所以最后就是a(3)=1+5+5=11…
同理你可以算出a(10)=1+5*9=46
满意请采纳
G. c语言函数递归调用
#include int Func(int n) { if(n < 2) return 1; else return n*Func(n-1); } int main() { int n = 5; printf("n! = %d\n",Func(n)); return 0; } 执行过程:-》Func(5) -》5*Func(4) -》5*(4*Func(3)) -》5*(4*(3*Func(2)))) -》5*(4*(3*(2*Func(1)))) 当n为0的时候停止递归,返回结果由于遇到1的时候返回1,那么Func(1)=1 所以结果是5*(4*(3*(2*1))) = 120
H. C语言,函数递归的调用
#include"stdio.h"
voidfun1(intn,intm){
if(m>0)
fun1(n,m-1);
printf("%-2d+%2d=%-2d",n,m,n+m);
}
voidfun2(intn,intm){
if(n>0)
fun2(n-1,m);
fun1(n,m-n);
printf(" ");
}
intmain(intargv,char*argc[]){
intN;
printf("InputN(int0<=N<=99)... N=");
if(scanf("%d",&N)!=1||N<0||N>99){
printf("Inputerror,exit... ");
return0;
}
fun2(N,N);
return0;
}
运行样例:
I. c语言递归函数,调用过程
从主函数fun(6,&x)开始调用。调用的时候,实参6和&x将自身的值传递给形参n,s,接着,开始执行fun函数体内的语句第一次调用:判断if(n==0||n==1),此时的n值为6,不满足条件,执行else部分语句。 fun(n-1,&f1);fun(n-2,&f2);先调用fun(n-1,&f1);而fun(n-2,&f2);需要当fun(n-1,&f1);符合if条件以后才轮到它执行第二次调用:此时,形参n=6转变为实参n,fun(n-1,&f1)等价于fun(5,&f1),继续判断,if(n==0||n==1),又不满足条件,于是,重复之前的操作,转向else部分执行。 fun(n-1,&f1);fun(n-2,&f2);此时的n=5,同样是先调用fun(n-1,&f1);后面那个fun(n-2,&f2);同样处于等待状态,等待前面的 fun(n-1,&f1);符合IF条件后才轮到它执行,于是,fun(n-1,&f1);就这样一层一层执行下去,每执行一次,n的值减一,当n=1的时候,执行if部分,这时,便可以在fun(n-1,&f1);执行完毕只有继续执行fun(n-2,&f2);,接着,返回前一次调用的状态,开始执行fun(n-2,&f2);比如当n=2的时候,执行完fun(2-1=1,&f1)以后,便开始执行fun(2-2=0,&f2);和它后面的语句,最终,函数返回上一次调用的状态,即fun(3,&f1);此时,fun(3,&f1)已经执行完毕,因为之前我们已经把fun(2,&f1)执行完了,接着,应该执行的是fun(3-2=1,&f2);当这个函数最后终也符合if部分要求,又返回到前面的fun(4,&f1),执行完后,开始执行fun(4,&f2),这样一个流程。通常来说,递归可以简化代码,但同时也会增加系统开销并且让程序阅读的时候要比正常的顺序程序难以理解一些。不过,现代的硬件飞速发展,用递归是完全可以的。
J. c语言函数的递归调用
递归有一个堆栈的概念,那就意味着他是一个反理解的过程:就象数学递推一样,你知道第一项,第二项,又知道通项公式,那你就可以知道任何一项。
然后你看代码:fun(0)==0,fun(1)==1;是告诉你一二项。
fun(n)==fun(n-1)+fun(n-2);是告诉你通项公式。那么,你就可以知道任何一项。你这样理解就差不多了,具体机器是怎么操作的,那很复杂的,也不需要明白!!!!