2
我是SML新手,正在做关于树遍历的练习。 这是问题的设置。标准ML二叉树遍历
datatype 'a bTree = nil | bt of 'a bTree * 'a * 'a bTree;
我需要编写一个函数inorder,它接受一个二叉树,并返回树中所有成员列表的顺序遍历。
我写这行:
fun inorder(nil) = nil
| inorder(bt(left,key,right)) = inorder(left) @ [key] @ inorder(right);
但得到一些错误,不知道如何解决:
Error: operator and operand don't agree [tycon mismatch]
operator domain: 'Z list * 'Z list
operand: 'Z list * 'Y bTree
in expression:
(key :: nil) @ inorder right
Error: operator and operand don't agree [tycon mismatch]
operator domain: 'Z list * 'Z list
operand: 'Y bTree * _
in expression:
inorder left @ (key :: nil) @ inorder right
谢谢你。我现在明白我的代码有什么问题了! – WilsonHoHK