首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尾递归和CPS

尾递归和CPS
EN

Stack Overflow用户
提问于 2014-02-11 11:24:32
回答 1查看 150关注 0票数 0

我已经被这个问题困扰了一段时间了。我将一个谓词和一个列表传递给scheme中的另一个函数。如果谓词为true,则将其添加到答案列表中,否则跳过它。

例如,(myfilt positive? '(1 -2 3))应为(1 3)。但我一直在找(1 . 0)

代码语言:javascript
复制
(define myfilt
   (letrec ([testfilt (lambda (x poly function)
                        (if (empty? poly)
                            (function '())
                            (testfilt x (rest poly)
                                      (lambda (v)
                                        (function (if (x (car poly))
                                                      (cons (car poly) v)
                                                      0))))))]
            [identity (lambda (x) x)])
     (lambda (x poly)
       (testfilt x poly identity))))
EN

回答 1

Stack Overflow用户

发布于 2014-02-11 12:05:49

对于else分支,您最内部的if应该使用v,而不是0。因此:

代码语言:javascript
复制
(if (x (car poly))
    (cons (car poly) v)
    v)
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21692440

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档