【发布时间】:2021-08-10 23:58:49
【问题描述】:
在教堂数字中,如果我们有:
# (define zero (lambda (f) (lambda (x) x)))
zero = lambda f: lambda x: x
那么后继函数可以定义为:
# (define succ (lambda (n) (lambda (f) (lambda (x) (f ((n f) x))))))
succ = lambda n: lambda f: lambda x: f(n(f)(x))
也许这是一个愚蠢的问题,但如果继任者实质上在前面的等式中添加了一个包装器f(...),为什么不能将其定义为f(n)?这更多是为了定义的一致性,还是为什么不能使用更短的形式?
(注意:这里使用 python 定义以及方案,因为它使我测试起来更简单。)
【问题讨论】:
标签: python functional-programming scheme lisp sicp