如果不使用内置于球拍中的 flatten 功能,如何将列表展平?
我知道 flatten 的默认实现是
(define (flatten lst)
(cond
((null? list)
empty)
((list? (car lst))
(append (flatten (car lst)) (flatten (cdr lst))))
(else
(cons (car lst) (flatten (cdr lst))))))
但我不完全确定如何不使用 flatten 功能,因为我不知道它在幕后是如何工作的。除了这段代码的实现之外,我找不到一个很好的解释。有人可以解释一下吗
这是我非常糟糕的尝试,我几乎一无所知,因为这甚至还没有接近并且不会运行....
(define acc null)
(define (my-flatten lst)
(cond
[(null? lst) null]
[(list? (car lst)) (help-flatten (car lst)) (append (cdr lst) acc)]
[else (append (car lst) acc) (my-flatten (cdr lst))]))
(define (help-flatten subLst)
(if (null? subLst)
(set! acc null)
(append (car subLst) acc))
(help-flatten (cdr subLst)))