首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用于ocaml的二进制参考树查找

用于ocaml的二进制参考树查找
EN

Stack Overflow用户
提问于 2015-10-23 04:57:31
回答 1查看 242关注 0票数 0
代码语言:javascript
运行
复制
type exp = V of var
           | P of var * exp
and var = string

我正在构建一个二进制参考树,其中右叶节点查找左叶节点上的叶节点,如果所有右叶节点与左叶节点匹配,则返回true。

代码语言:javascript
运行
复制
let rec ctree : exp * exp -> bool
=fun (e1,e2) -> match e2 with
  | P (x,y) -> match y with
    | P (a,b) -> if (ctree(a,b)) then true else ctree(x,b)
    | V a -> if a=x then true else ctree(e1,y)
  | V x -> e1=x

但是在这里,我经常在第5行出现错误:

代码语言:javascript
运行
复制
| V a -> if a=x then true else ctree(e1,y)

这里的e1有一个类型exp,应该是这样的,但是编译器一直告诉我它应该是var=string类型。另外,对于第6行,

代码语言:javascript
运行
复制
V x -> e1=x

它告诉我,应该再次使用var=string类型而不是e1类型。

有人能告诉我为什么会出错吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-23 05:14:56

当您有两个嵌套的match表达式时,不清楚嵌套的结束位置。您需要在内部匹配周围使用括号。像这样的东西可能会起作用:

代码语言:javascript
运行
复制
let rec ctree : exp * exp -> bool =
    fun (e1,e2) -> match e2 with
    | P (x,y) ->
        (match y with
        | P (a,b) -> if (ctree(a,b)) then true else ctree(x,b)
        | V a -> if a=x then true else ctree(e1,y)
        )
    | V x -> e1=x

其次,函数的类型是exp * exp -> bool,它表示e1exp类型。在函数的末尾,您可以看到以下内容:

代码语言:javascript
运行
复制
| V x -> e1 = x

因为xV构造函数的值,所以它必须是字符串。但是,只有当e1 = x也是字符串时,e1才有意义。

因此,在使用e1时存在类型冲突。

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

https://stackoverflow.com/questions/33295144

复制
相关文章

相似问题

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