sicp 3.12 3.13 3.14习题解答
习题3.12,append不是改变函数,不会改变x的结构。append!是改变函数,显然第一个response是(b),第二个就是(b c d)。图就不画了,画了一次太麻烦了。
习题3.13,利用set-cdr!形成环,比较有意思:
(define z (make-cycle (list 'a 'b 'c 'd)))
z在DrScheme上表示为:
#0=(a b c d . #0#)
形象地展示了一个环,显然运行(last-pair z)将陷入无限递归,因为(null? (cdr x))永远不会为真。
习题3.14,这道题运行下就知道了,是个倒排list的过程,分析下(mystery v)的运行过程:
(loop (a b c d) '())
(loop (b c d) (a '()))
(loop (c d) (b a))
(loop (d) (c b a))
(loop '() (d c b a))
习题进度落后于读书进度,残念
文章转自庄周梦蝶 ,原文发布时间2007-10-18
最后更新:2017-05-17 17:01:51
上一篇:
得到singleton类?
下一篇:
写一个简单的工作流(四)资源的处理
25岁Java工程师如何转型学习人工智能?
谈谈分布式事务之二:基于DTC的分布式事务管理模型[上篇]
Linux问题情报分享(3):CentOS 7上最新kernel-debuginfo包与内核不匹配导致SystemTap脚本运行失败
D-News | 洲际旗下12家酒店遭大规模数据泄露 Snap收购以色列明星AR公司
要采购阿里云虚拟主机/万网空间,这些门道你必须知道!
如何查看自己的主机是否安装了Zend Guard Loader组件
苹果为什么要做iPad mini?
人工智能可以为医疗带来什么
linux c 进程 pipe 通信代码分析
一份报告看懂新疆旅游电子商务发展状况