Scheme - 列表总和

时间:2013-02-22 08:03:53

标签: functional-programming scheme

我正在尝试实现一个用于计算列表总和的函数,其名称为sum -

(define (sum elemList)
  (if
   (null? elemList)
   (+ (car elemList) (sum (cdr elemList)))
   0
  )
 )

上述实现给出了错误的结果,例如 -

> (sum (list 1 2 3 4 ))
0

我在这里做错了什么?

3 个答案:

答案 0 :(得分:6)

我认为你交换了然后if else 部分:

(define (sum elemList)
  (if
    (null? elemList)
    0
    (+ (car elemList) (sum (cdr elemList)))
  )
)

在原始函数中,对于每个非空列表,都会返回0

答案 1 :(得分:1)

您也可以使用apply

(define (sum elemList) (apply + elemList))

应该给您相同的结果

答案 2 :(得分:0)

请参阅此链接以获取更多详细信息。 -http://groups.umd.umich.edu/cis/course.des/cis400/scheme/listsum.htm

(define(list-sum lst)
    (cond
((null ? lst)
    0)
((pair? (car lst))
    (+(list-sum (car lst)) (list-sum (cdr lst))))
(else
    (+ (car lst) (list-sum (cdr lst))))))