移除/删除 SML 中的子树

发布于 2024-09-25 06:06:18 字数 78 浏览 0 评论 0原文

嘿,我想编写一个函数删除,给定一棵树,我可以删除树中的一个节点,因此它应该返回原始树减去该节点和该节点的子树。 每个提示都有帮助,提前感谢:)

Hey, i want to program a function delete that given a tree, i can delete a node in the tree so it should return the original tree minus the node and the subtree of this node.
every hint helps, and thanx in advance:)

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

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

发布评论

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

评论(1

嗳卜坏 2024-10-02 06:06:18
(*declaration for tree *)
datatype 'a tree 
  = Empty
  | Node of 'a tree * 'a * 'a tree

(* function to compare trees *)
fun eqTree (t, t' : ''a tree) : bool =
  case (t, t')
    of (Empty, Empty) => true
     | (Node(l,x,r), Node(l',x',r')) =>
         x = x'       andalso
         eqTree(l,l') andalso
         eqTree(r,r')
     | (Empty, Node _) => false
     | (Node _, Empty) => false 

(* function to remove all trees t' from t *)
fun rmTree (t, t' : ''a tree) = 
  case (t, t')
    of (Empty, Empty) => Empty
     | (Node(l,x,r), Node(l',x',r')) => if x=x' andalso eqTree(l, l') andalso eqTree(r, r') then Empty else Node((rmTree(l,t')), x, rmTree(r,t'))
     | (Empty, Node _) => Empty
     | (Node a, Empty) => Node a ;

(* an example *)
rmTree(rmTree((Node(Node(Empty,3,Empty), 2, Node(Empty,2,Empty))), (Node(Empty,2,Empty))), (Node(Empty,2,Empty))); 
(*declaration for tree *)
datatype 'a tree 
  = Empty
  | Node of 'a tree * 'a * 'a tree

(* function to compare trees *)
fun eqTree (t, t' : ''a tree) : bool =
  case (t, t')
    of (Empty, Empty) => true
     | (Node(l,x,r), Node(l',x',r')) =>
         x = x'       andalso
         eqTree(l,l') andalso
         eqTree(r,r')
     | (Empty, Node _) => false
     | (Node _, Empty) => false 

(* function to remove all trees t' from t *)
fun rmTree (t, t' : ''a tree) = 
  case (t, t')
    of (Empty, Empty) => Empty
     | (Node(l,x,r), Node(l',x',r')) => if x=x' andalso eqTree(l, l') andalso eqTree(r, r') then Empty else Node((rmTree(l,t')), x, rmTree(r,t'))
     | (Empty, Node _) => Empty
     | (Node a, Empty) => Node a ;

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