作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在阅读 Huet Zipper ,我无法理解 go_up 方法:
let go_up (Loc(t,p)) = match p with
Top -> failwith "up of top"
| Node(left,up,right) -> Loc(Section((rev left) @ (t::right)),up);;
Location
包含当前节点及其
Path
或所谓的
Context
.
Path
拥有除当前节点及其子节点之外的所有内容,或者有人称其为
a one-hole-context
.
最佳答案
这里的 zipper 适用于以下树数据类型:
type tree =
Item of item
| Section of tree list;;
type path =
Top
| Node of tree list * path * tree list;;
Node
包含三个组件。位于孔左侧的父节点的子节点 (
left
)、更上方的路径 (
up
) 以及位于孔右侧的父节点的子节点 (
right
) .
t
在
left
之间的正确位置和
right
.由于左边的 child 是以相反的顺序存储的,我们必须先将它们反转。
关于scala - 如何在 HUET zipper 内向上导航,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12129300/
我正在阅读 Huet Zipper ,我无法理解 go_up 方法: let go_up (Loc(t,p)) = match p with Top -> failwith "up of top" |
我正在比较 Huet's original paper与 Clojure's implementation并试图弄清楚为什么要进行更改。我是 Clojure 新手,所以如果我对 Clojure 代码的
我是一名优秀的程序员,十分优秀!