c语言ans作用,C语言的递归思想实例分析

本文实例分析C语言的递归思想,分享给大家供大家参考之用。具体方法如下:

通俗点来说,递归就是自己调用自己。

递归的难点一是理解递归的执行调用过程,二是设置一个合理的递归结束条件。

下面来看一段摘自书中的简单程序:

#include

long fact(int n);

long rfact(int n);

int main(void)

{

int num;

printf("This program calculates factorials.n");

printf("Enter a value in the range 0-12 (q to quit):n");

while(scanf("%d",&num)==1)

{

if(num12)

{

printf("Keep input under 13.n");

}

else

{

printf("loop:%d factorial=%dn",num,fact(num));

printf("recursion:%d factorial=%dn",num,rfact(num));

}

}

}

long fact(int n)

{

long ans;

for (ans=1;n>1;n--)

{

ans*=n;

}

return ans;

}

long rfact(int n)

{

long ans;

if (n>0)

{

ans=n*rfact(n-1);

}

else

{

ans=1;

}

return ans;

}

该程序用来计算阶乘,分别采用循环和递归实现。用语言来描述一下递归的执行过程吧。

假设计算5!,n=5,分别调用了自己4次,即n分别等于4,3,,2,1。当n等于0时,返回ans=1,这时rfact这个函数才刚刚完整的执行一遍,返回ans=1,

压栈已经完成,开始出栈。

n与ans,分别相乘5次,即ans分别等于1,2,6,24,120(24*5)

即5!=120

我们来看一下n的变化规律:

入栈时,n=5,4,3,2,1,

出栈时,n=1,2,3,4,5

递归实质上就是栈。

往往容易忽略递归条件不满足后,被调函数把控制权转会主调函数,主调函数继续执行剩余的语句这一过程,而造成迷惘。

其实,所有事情都可以用生活中的事情加以解释,就像四大名著相互相通,可以互相解释一样,做一件事情可以不要求甚至不清楚最后的结果,但是一定要明白这件事情是在做什么,明白这件事情来龙去脉,但是不要死钻牛角尖,静心做学问。

感兴趣的朋友可以测试运行本文实例以加深理解,相信本文所述对大家C程序设计的学习有一定的借鉴价值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值