我正在尝试创建一个方案尾递归函数 flatten-tl-rec 来展平嵌套的列表列表。
(define flatten-tl-rec
(lambda (xs)
(letrec ([flatten-tl-rec-acc
(lambda (xs acc)
(cond ((empty? xs) acc)
((list? (first xs)) (flatten-tl-rec-acc (rest xs) (append (flatten-tl-rec-acc (first xs) '()) acc)))
(else (flatten-tl-rec-acc (rest xs) (cons (first xs) acc))))
)])
(flatten-tl-rec-acc xs '()))))
(flatten-tl-rec '(1 2 3 (4 5 6) ((7 8 9) 10 (11 (12 13)))))
但我得到(13 12 11 10 9 8 7 6 5 4 3 2 1)
的不是(1 2 3 4 5 6 7 8 9 10 11 12 13)
. 这里有什么问题?