首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OCaml中的优先级和关联;计算加泰罗尼亚数时的意外结果

OCaml中的优先级和关联;计算加泰罗尼亚数时的意外结果
EN

Stack Overflow用户
提问于 2020-10-24 23:24:52
回答 1查看 104关注 0票数 0

计算第n个加泰罗尼亚数的简单函数中的意外行为。

代码语言:javascript
复制
let rec catalan x =
    match x with
        0 -> 1
        | n -> catalan(n - 1) * 2 * (2 * n - 1) / (n + 1)

这给出了预期的答案(例如,加泰罗尼亚3 -> 5)。

然而,

代码语言:javascript
复制
let rec catalan2 x =
    match x with
        0 -> 1
        | n -> (2 * (2 * n - 1) / (n + 1)) * catalan2(n - 1)

给出意想不到的(不正确的)答案(例如,加泰罗尼亚3 -> 4)。

在我看来,这些应该在语义上是相同的。在OCaml中,有什么关于操作符优先级的事情我误解了吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-24 23:33:36

这不是整数操作的标识:

代码语言:javascript
复制
(a * b) / c = (b / c) * a

例如:

代码语言:javascript
复制
(2 * 5) / 3 =? (5 / 3) * 2
10 / 3 =? 1 * 2
3 =? 2

整数除法操作/不同于通常的数学除法(对于实数)。

更新

你有这个:

代码语言:javascript
复制
catalan(n - 1) * 2 * (2 * n - 1) / (n + 1)

你声称它应该与此完全相同:

代码语言:javascript
复制
(2 * (2 * n - 1) / (n + 1)) * catalan (n - 1)

让我们给子表达式取名字。那你就有了这个

代码语言:javascript
复制
a * b * c / d

你说它应该与此相同:

代码语言:javascript
复制
(b * c / d) * a

事实并非如此。这是我上面展示的一个稍微复杂一些的版本。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64518937

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档