俺是 Lisp 初学者, 先从 Scheme 建立函式语言的感觉,
刚刚开始刷: The Little Schemer - 4th Edition (豆瓣)
环境:
; member? _v1 尝试将探索过程打印出来
(define iter4cond ()) ; 声明寄存容器
(define member1? ; 声明函式
(lambda (a lat) ; 绑定匿名函式, 接收参数 a lat
(set! iter4cond (cons iter4cond lat)) ; ???
(cond ; 系列 if 判定
((null? lat) #f) ; 法则->先检验 目标原子是否为空? 是, 直接退出并返回 #f
(else (or ; 否则 or 一下两种对比
;(define lat1st (car lat))
;(display lat1st)
(eq? (car lat) a) ; 第一个成员是否和 对比原子相同?
;(eq? lat1st a) ; 第一个成员是否和 对比原子相同?
(member1? a (cdr lat)) ; 对其它成员使用 member 进行检验
)
)
)
)
)
所以, 不得不用过程语言的方法, 通过全局列表收集过程中的数据,
再另外打印:
比如:
(define lat `(fried eggs and scrambled egg))
(define b 'and)
(member1? b lat)
=> #t
再
iter4cond
才能输出:
(((() fried eggs and scrambled egg) eggs and scrambled egg) and scrambled egg)
可能还得另外构建合理的可视化输出函式,
所以, 俺的问题是, 这种场景中, 是否可以在计算过程中, 安全输出中间数据, 而又不干挠正常的迭代展开?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.