c语言程序函数递归解析,c语言中的递归函数

C语言函数递归的理解

int main(int argc, char *argv[])

创新互联建站从2013年创立,先为日喀则等服务建站,日喀则等地企业,进行企业商务咨询服务。为日喀则企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

main参数 argc 是保存命令的个数,argv 保存命令

例如 test -a -b -c

test程序启动时接受了 4个参数(默认 test也属于一个参数 ),个数保存到argc -a -b -c 保存到argv

递归。我觉得你被这个名气搞晕了而已,其实就很简单,在某个函数中再调用这个函数,就叫递归

例如

int test(int a)

{

return test(a+1); //死循环 ,不断进入test函数 a不断加1。。。。

} //你可以理解为一个for 或者while的另一种形式,反正就是循环,加判断以停止递归调用

c语言中,什么是函数的递归?

所谓递归,说的简单点,就是函数自己调用自己,然后在某个特定条件下。结束这种自我调用。

如果不给予这个结束条件,就成了无限死循环了。这样这个递归也就毫无意义了。

如下面问题

1 1 2 3 5 8 13 21 ........n

分析可以看出, i 表示第几个数, n 表示该数的值

当i = 1 时, n = 1;

当i = 2 时, n = 1;

当i = 3 时 n = i1 + i2;

当i = 4 时 n = i2 + i3

所以可以写个函数

int fun(int n) // 这里的n代表第几个数

{

if(1 == n || 2 == n) // 第一个数

{

return 1;

}

else

{

return fun(n - 1) + fun(n - 2); // 这里就是自己调用自己,形成循环自我调用。

}

}

注: 以上代码只是用来演示递归,不包含错误校验。

在实际生产过程中。该代码不够健壮。

如此,就完成了递归。你就可以求得第n个数了。

何时考虑使用递归。

当你分析一个问题的时候,发现这个问题,是一个自我循环时,而且这个自我循环到一个给定值,就可以终止的时候,你就快要考虑递归了。

C语言 递归程序 求解

递归函数就是做了一件事:求和

递归过程如下:

第一次进入:n==3, 执行的是 p[0]+f(p[1],2);这样的话会继续调用函数f,也就有了第二次进入。

第二次进入:表达式变成了p[0]+p[1]+f[p[1],1],这样的话会继续调用函数f,也就有了第三次进入。

第三次进入:n==1, p[0]+p[1]+p[2].

return (p[0]+f(p[1],2)=p[0]+p[1]+f[p[1],1]=p[0]+p[1]+p[2])--return p[0]+p[1]+p[2]

递归一般是出于效率的要求,当然你这个没什么影响。递归也不是用在这里的。看递归要干什么很简单,看两点:1.递归退出条件是什么,退出时的返回值;2.递归时在做什么。

c语言 递归函数解释

假设n=9

1判断n=9非0,把n=9压入栈中,执行ttor(4);栈中为9

2判断n=4非0,把n=4压入栈中,执行ttor(2);栈中为9,4

3判断n=2非0,把n=2压入栈中,执行ttor(1);栈中为9,4,2

4判断n=1非0,把n=1压入栈中,执行ttor(0);栈中为9,4,2,1

5判断n=0不满足条件,函数结束

6从栈中取出n=1,执行ttor(1)的剩余部分,输出1

7从栈中取出n=2,执行ttor(2)的剩余部分,输出0

8从栈中取出n=4,执行ttor(4)的剩余部分,输出0

9从栈中取出n=9,执行ttor(9)的剩余部分,输出1


分享标题:c语言程序函数递归解析,c语言中的递归函数
网页URL:http://csdahua.cn/article/hcehoi.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流