免费注册 查看新帖 |

Chinaunix

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

pattern matching 代码顺序影响运行的效率吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-01 20:02 |只看该作者 |倒序浏览
代码如下?

  1. factorial1 0 = 1
  2. factorial1 (n+1) = (n+1) * factorial1 n
复制代码

  1. factorial2 (n+1) = (n+1) * factorial2 n
  2. factorial2 0 = 1
复制代码

以上两个函数运行的效率后者快一些吗?

[ 本帖最后由 izhier 于 2009-4-1 20:04 编辑 ]

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
2 [报告]
发表于 2009-04-01 22:14 |只看该作者

回复 #1 izhier 的帖子

Haskell 的 pattern matching 是顺序进行的,因此,针对你的例子,理论上来说,后面的是会快一点。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2009-04-02 13:27 |只看该作者
原帖由 MMMIX 于 2009-4-1 22:14 发表
Haskell 的 pattern matching 是顺序进行的,因此,针对你的例子,理论上来说,后面的是会快一点。

后面那种会不会导致 0 永远都匹配不上啊?

论坛徽章:
0
4 [报告]
发表于 2009-04-02 14:17 |只看该作者

回复 #3 flw 的帖子

不会, factorial2 (n+1) 是所谓的 n+k patterns,其行为有点令人感到意外。

factorial2 (n+1) 不会匹配 factorial2 0,它只匹配 >= 1 的值。

[ 本帖最后由 win_hate 于 2009-4-2 14:25 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2009-04-02 14:55 |只看该作者
在 pattern matching 中用 (n+1) 来匹配大小为 >= 1 的参数, (n+k) 来匹配大小为 >= k 的参数

其实下面的代码有一个 bugger

  1. factorial 0 = 1
  2. factorial n = n * factorial (n-1)
复制代码

就是:当 n 为负数时,将会产生
ERROR - Control stack overflow

[ 本帖最后由 izhier 于 2009-4-2 15:08 编辑 ]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
6 [报告]
发表于 2009-04-02 15:16 |只看该作者
原帖由 izhier 于 2009-4-2 14:55 发表
在 pattern matching 中用 (n+1) 来匹配大小为 >= 1 的参数, (n+k) 来匹配大小为 >= k 的参数

其实下面的代码有一个 bugger

factorial 0 = 1
factorial n = n * factorial (n-1)

就是:当  ...

这个我倒不认为是 BUG。
定义域之外的东西,不需要过分地去关心它。
只需要做 UI 的时候注意就可以了。

论坛徽章:
0
7 [报告]
发表于 2009-04-27 17:04 |只看该作者
这个我倒不认为是 BUG。
定义域之外的东西,不需要过分地去关心它。
只需要做 UI 的时候注意就可以了。


支持

论坛徽章:
0
8 [报告]
发表于 2009-04-27 17:39 |只看该作者
不知为何 haskell 要添加 pattern matching 中 +  这一特例 ?

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
9 [报告]
发表于 2009-04-27 17:51 |只看该作者
原帖由 izhier 于 2009-4-27 17:39 发表
不知为何 haskell 要添加 pattern matching 中 +  这一特例 ?

向数学书写习惯靠拢撒,类似的还有 [ x | ...]

论坛徽章:
0
10 [报告]
发表于 2009-04-27 18:00 |只看该作者
原帖由 MMMIX 于 2009-4-27 17:51 发表

向数学书写习惯靠拢撒,类似的还有 [ x | ...]

对了,还有
guards 好像数学中的大括号分类
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP