作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我写了一个中序树遍历函数:
let rec inOrder (tree: BinTree<'a>) : 'a list =
match tree with
| Leaf -> []
| Node(x,l,r) -> (inOrder l) @ [x] @ (inOrder r)
现在我想使用这个函数来“映射”所有笔记并应用作为参数给出的函数。它应该接受一个函数和一棵树,然后返回一棵树。这是我到目前为止所拥有的:
let mapInOrder f t =
inOrder t
|> Map.ofList
例如,如果我向函数提供以下输入:
mapInOrder float (Node(1,Node(2,Leaf,Leaf),Node(3,Leaf,Leaf)));;
我想要输出:
(Node(1.0,Node(2.0,Leaf,Leaf),Node(3.0,Leaf,Leaf)))
最佳答案
要将函数映射到List
,请使用函数List.map
:
let mapInOrder f t =
inOrder t
|> List.map f
但是这个函数会产生一个列表作为输出。您的示例将产生:
[ 1.0 ; 2.0 ; 3.0 ]
要生成您期望的输出,您的 mapInOrder
应该在将函数应用于每个元素后遍历树,生成另一棵树。
关于.net - 中序遍历树并将给定函数应用于所有节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55000670/
序 大家好呀,我是summo,这次来写写我在上班空闲(摸鱼)的时候做的一个小网站的事。去年阿里云不是推出了个活动嘛,2核2G的云服务器一年只要99块钱,懂行的人应该知道这个价格在业界已经是非常良心了
我尝试根据给定的级别顺序(BFS 顺序)构造 BST。我知道这是可能的,但我不知道我该怎么写。问题是我必须使用 BFS 序列。所以,我不能在这里使用递归,我必须迭代地编写我的程序......我发现这有
我是一名优秀的程序员,十分优秀!