lisp中奇数元素的总和
Sum of odd elements in lisp
我必须对奇数位置上的奇数元素求和。这是行不通的。有人可以告诉我我的错误在哪里吗?谢谢
(defun sum (list)
(cond
((null list) 0)
((= (mod 2 (car list)) 0) (sum (cddr list)))
(T (+ (car list) (sum (cddr list))))))
检查函数参数的顺序 mod。应该是:
(= (mod (car list) 2) 0)
为避免此错误,您可以改用函数 evenp。
您的原始定义(对奇数位置的奇数元素求和)实际上非常干净地转换为循环:
(loop for i from 0
for x in '(0 1 2 3 4 5 6)
when (and (oddp i) (oddp x))
sum x)
您的原始解决方案在列表中下移了 cddr,这实际上是一个很好的方法。您也可以使用 loop 来完成(最初调用 rest 只是为了让事情从索引 1 开始):
(loop for x in (rest '(0 1 2 3 4 5 6)) by #'cddr
when (oddp x)
sum x)
我必须对奇数位置上的奇数元素求和。这是行不通的。有人可以告诉我我的错误在哪里吗?谢谢
(defun sum (list)
(cond
((null list) 0)
((= (mod 2 (car list)) 0) (sum (cddr list)))
(T (+ (car list) (sum (cddr list))))))
检查函数参数的顺序 mod。应该是:
(= (mod (car list) 2) 0)
为避免此错误,您可以改用函数 evenp。
您的原始定义(对奇数位置的奇数元素求和)实际上非常干净地转换为循环:
(loop for i from 0
for x in '(0 1 2 3 4 5 6)
when (and (oddp i) (oddp x))
sum x)
您的原始解决方案在列表中下移了 cddr,这实际上是一个很好的方法。您也可以使用 loop 来完成(最初调用 rest 只是为了让事情从索引 1 开始):
(loop for x in (rest '(0 1 2 3 4 5 6)) by #'cddr
when (oddp x)
sum x)