pattern matching 代码顺序影响运行的效率吗?

发布于 2022-08-19 05:45:04 字数 315 浏览 21 评论 9

代码如下?

  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 编辑 ]

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

野心澎湃 2022-08-21 23:56:22

原帖由 MMMIX 于 2009-4-27 17:51 发表

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

对了,还有
guards 好像数学中的大括号分类

初吻给了烟 2022-08-21 23:56:16

原帖由 izhier 于 2009-4-27 17:39 发表
不知为何 haskell 要添加 pattern matching 中 +  这一特例 ?

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

咆哮 2022-08-21 23:52:48

不知为何 haskell 要添加 pattern matching 中 +  这一特例 ?

成熟的代价 2022-08-21 23:52:41

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

支持

还如梦归 2022-08-21 23:50:50

原帖由 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 的时候注意就可以了。

GRAY°灰色天空 2022-08-21 23:17:18

在 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 编辑 ]

只为守护你 2022-08-21 19:16:12

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

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

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

雨的味道风的声音 2022-08-21 17:50:10

原帖由 MMMIX 于 2009-4-1 22:14 发表
Haskell 的 pattern matching 是顺序进行的,因此,针对你的例子,理论上来说,后面的是会快一点。

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

伴我心暖 2022-08-19 21:41:39

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文