免费注册 查看新帖 |

Chinaunix

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

实现尾递归优化的一点思路 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-11 00:26 |显示全部楼层 |倒序浏览
本帖最后由 3P主义 于 2012-03-11 00:27 编辑

不精确的概括,所谓尾递归,就是在函数里最后一条里调用自身;如果没有尾递归优化的话,在栈上要保存无数个函数的返回地址;在很多函数式语言里,有所谓的尾递归优化;在 Perl 里如何达到尾递归的效果?可以考虑借助 goto :

  1. #!/bin/env perl

  2. use strict;
  3. use warnings;

  4. print func(100);

  5. sub func {
  6.     my ($n, $sum) = @_;
  7.     $sum = 1 if (not defined $sum);

  8.     if ($n <= 1) {
  9.         return $sum;
  10.     }
  11.     else {
  12.         $sum *= $n;
  13.         @_ = ($n - 1, $sum);
  14.         goto(&func);
  15.     }
  16. }

  17. sub func2 {
  18.     my ($n, $sum) = @_;
  19.     $sum = 1 if (not defined $sum);

  20.     if ($n <= 1) {
  21.         return $sum;
  22.     }
  23.     else {
  24.         $sum *= $n;
  25.         return func2($n - 1, $sum);
  26.     }
  27. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP