免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2048 | 回复: 5
打印 上一主题 下一主题

[算法] c关于递归工作站的工作方式 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-04-06 20:30 |只看该作者 |倒序浏览
这里有两个简单的实现n的阶乘的代码,请高手分析分析pro1是不是算是递归实现,而这两段代码是如何在递归工作站实现的。
pro1:
#include<stdio.h>
unsigned long jc(unsigned int,unsigned long);
int main(int argc,char **argv)
{printf("Please input the numnber:");
unsigned int n; unsigned long sum=1;
scanf("%d",&n);
printf("%ld\n",jc(n,sum));
return 0;
}
unsigned long jc(unsigned int n,long unsigned sum)
{
  if(n==0){sum*=1;return sum;}
else
{sum*=n;

jc(n-1,sum);
}
}
pro2:
#include<stdio.h>
unsigned long jc(unsigned int,unsigned long);
int main(int argc,char **argv)
{printf("Please input the numnber:");
unsigned int n; unsigned long sum=1;
scanf("%d",&n);
printf("%ld\n",jc(n,sum));
return 0;
}
unsigned long jc(unsigned int n,long unsigned sum)
{
  if(n==0)sum=1;
else
sum=n*jc(n-1,sum);

return sum;           

}

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
2 [报告]
发表于 2011-04-06 21:45 |只看该作者
第一个尾递归吧。

论坛徽章:
0
3 [报告]
发表于 2011-04-07 22:47 |只看该作者
第一个我可以弄清楚进出栈的工作方式,第二个能说的清楚些吗?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:56:11
4 [报告]
发表于 2011-04-07 23:56 |只看该作者
都是遞歸

何謂遞歸?
1,自己調用自己
2,函數交叉調用


建議階乘不用使用遞歸

论坛徽章:
3
15-16赛季CBA联赛之山东
日期:2016-10-30 08:47:3015-16赛季CBA联赛之佛山
日期:2016-12-17 00:06:31CU十四周年纪念徽章
日期:2017-12-03 01:04:02
5 [报告]
发表于 2011-04-08 06:35 |只看该作者
本帖最后由 captivated 于 2011-04-08 06:37 编辑
第一个我可以弄清楚进出栈的工作方式,第二个能说的清楚些吗?
houpp1989 发表于 2011-04-07 22:47



    很容易清楚的。运行时栈不就是一个随着运行时函数调用深入不断增长/缩减的动态影像嘛。

    对于交叉递归的情况,假使f1->f2->f1->f2->f1->f2->f1,
    那栈帧不就是这样子的嘛!:
    f1  (高地址栈帧)
    f2
    f1
    f2
    f1
    f2
    f1   (低地址栈帧)
     ......
    以上说明基于大多数x86上的系统实现。
    返回的时候按次序弹栈返回就得了啊...靠,搞那么复杂干嘛。

论坛徽章:
3
15-16赛季CBA联赛之山东
日期:2016-10-30 08:47:3015-16赛季CBA联赛之佛山
日期:2016-12-17 00:06:31CU十四周年纪念徽章
日期:2017-12-03 01:04:02
6 [报告]
发表于 2011-04-08 06:49 |只看该作者
本帖最后由 captivated 于 2011-04-08 06:52 编辑

LZ的两个pro都不是交叉递归,因为都是函数自己调用自己。
栈帧嘛,
jc
jc
jc
jc
....
直到某个jc return。
然后可能栈帧又开始增长?又直到return。懒得分析,脑袋搭铁。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP