- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
来自 SICP
Exercise 2.24: Suppose we evaluate the expression (list 1 (list 2 (list 3 4))). Give the result printed by the interpreter, the corresponding box-and-pointer structure, and the interpretation of this as a tree (as in Figure 2.6).
问题是我的眼睛坏了,所以我既看不到盒子和指针图,也看不到图2.6。所以现在我只能猜测这个列表应该像树一样基于:
Another way to think of sequences whose elements are sequences is as trees. The elements of the sequence are the branches of the tree, and elements that are themselves sequences are subtrees.
请检查我的树解释。这只是我的想象。我非常有信心这是正确的,但无法确认,因为我找到的所有练习答案都是图片,我的屏幕阅读器无法阅读它们。
(list 1 (list 2 (list 3 4))) - 我认为这是树本身,或者根节点。这棵树有两个分支或 child 。
第一个分支 (1) 是叶节点,因此我们在树的这一侧完成。
第二个分支(list 2(list 3 4)是另一棵树。
现在我们关注子树(列表 2(列表 3 4)。它有两个 child /分支。
第一个分支是叶节点 (2),所以我们到这里就完成了。
第二个分支是另一棵树(列表 3 4)。
现在我们关注子树(列表 3 4)。它有两个子分支。
它们都是叶节点,所以我们完成了。
这是正确的吗?我对这棵树的理解正确吗?
最佳答案
Lisp 中真正的列表构建原语是cons
。作为评估形式 (list 1 2 3)
的结果的列表与评估 (cons 1 (cons 2 (cons 3 '())))
,也可以写成 '(1 2 3 . ())
,或者全点形式 '(1 . (2 . (3 . ())) )
。
所有这些都将被解释器打印为(1 2 3)
:
(list 1 2 3) '(1 2 3) ; (1 2 3)
(cons 1 (list 2 3)) '(1 . (2 3)) ; (1 2 3)
(cons 1 (cons 2 (list 3))) '(1 . (2 . (3))) ; (1 2 3)
(cons 1 (cons 2 (cons 3 '()))) '(1 . (2 . (3 . ()))) ; (1 2 3)
从树的角度来看,(1 2 3)
有三个分支 - 都是叶节点:1、2 和 3。另一方面,(1 (2 3))
有两个分支——一个叶子和一个由两个叶子节点组成的树。并且 ((1 2) 3)
也有两个分支 - 一个有两个叶分支的树,和一个叶分支。
作为框和指针结构,点代表 cons 单元(即框),每个单元都有两个槽或指针 - car
(在点的左侧)和cdr
(在点的右边)。
因此,评估 (list 1 (list 2 3))
的结果,打印为 (1 (2 3))
,也是由调用 (cons 1 (cons (cons 2 (cons 3 '())) '()))
;所以作为一个框指针结构,它实际上是 '(1 . ( (2 . (3 . ())) . () ))
。它的car
是1
,它的cdr
是盒子( (2 . (3 . ())) . () )
其 cdr
是 ()
及其 car
- 盒子 (2 . (3 . ()))
;等等
在其最后一个框的 cdr
中带有 ()
的列表被称为“正确列表”。任何其他的都被称为“不正确的列表”,例如
'(1 2 . 3)
= '(1 . (2 . 3))
= (cons 1 (cons 2 3))
关于list - 理解 SICP 中的树 - 练习 2.24,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34605872/
我想使用 R 预定义这样的列表 DATA<-list( list(list(),list(),list()), list(list(),list(),list()), list(list(),l
如何将一个列表添加到另一个列表,返回一个列表的列表? foo :: [a] -> [a] -> [[a]] 例如,我想要的结果是: foo [1,2] [3,4] 将是 [[1,2], [3,4]]。
我还没有在这里找到类似问题的解决方案,所以我会寻求你的帮助。 有 2 个列表,其中之一是列表列表: categories = ['APPLE', 'ORANGE', 'BANANA'] test_re
这个问题不同于Converting list of lists / nested lists to list of lists without nesting (这会产生一组非常具体的响应,但无法解决
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在下面的代码中,get()被调用并将其结果分配给类型为 List> 的变量. get()返回 List>并在类型参数为 T 的实例上调用设置为 ? ,所以它应该适合。 import java.util
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在insufficiently-polymorphic 作者说: def foo[A](fst: List[A], snd: List[A]): List[A] There are fewer way
我有下面的代码有效。 class ListManipulate(val list: List, val blockCount: Int) { val result: MutableList>
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 5 年前。 Improve this ques
在 scala (2.9) 中转换列表列表的最佳方法是什么? 我有一个 list : List[List[A]] 我想转换成 List[A] 如何递归地实现这一点?或者还有其他更好的办法吗? 最佳答案
我编写了这个函数来确定给定元素是否存储在元组列表的列表中,但目前它只搜索第一个列表。我将如何搜索其余列表? fun findItem (name : command, ((x,y)::firstlis
我创建了一个类名 objectA,它有 4 个变量:约会时间;字符串文本;变量 1,变量 2 我需要创建一个 ObjectA() 列表。然后首先按时间对它们进行分组,其次按 var1,然后按 var2
我有一套说法 char={'J','A'} 和列表的列表 content = [[1,'J', 2], [2, 'K', 3], [2, 'A', 3], [3,'A', 9], [5, 'J', 9
我有以下列表 List >>> titles = new ArrayList >>> ();我想访问它的元素,但我不知道该怎么做.. 该列表有 1 个元素,它又包含 3 个元素,这 3 个元素中的
转换 List[List[Long]] 的最佳方法是什么?到 List[List[Int]]在斯卡拉? 例如,给定以下类型列表 List[List[Long]] val l: List[List[Lo
我有一个来自 Filereader (String) 的 List-List,如何将其转换为 List-List (Double):我必须返回一个包含 line-Array 的第一个 Values 的
我收集了List> 。我需要将其转换为List> 。这是我尝试过的, List> dataOne = GetDataOne(); var dataTwo = dataOne.Select(x => x
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
我是一名优秀的程序员,十分优秀!