我正在处理球拍中的列表,我正在做一个添加项目的函数。我做到了
(define (iter lst [acc '()])
(if (null? lst)
(append (list acc))
(iter10 (cdr lst) (append acc (caar lst)))))我的产出是:
(iter10 '(((1 2)(3 4)(5 6))((7 8)(9 10)(11 12))))
'((1 2 7 8))但我想要产出:
(iter10 '(((1 2)(3 4)(5 6))((7 8)(9 10)(11 12))))
'((1 2 7 8) (3 4 9 10) (5 6 11 12))(iter10 '(((1 2)(3 4)(5 6))((7 8)(9 10)(11 12))((1 2)(3 4)(5 6))))
'((1 2 7 8 1 2) (3 4 9 10 3 4) (5 6 11 12 5 6))我知道这是因为caar的使用,但我不知道该怎么做。有一个主列表,其中有几个列表。我希望所有元素都能通过位置连接起来。主名单的数量可能是任意的。谢谢
发布于 2022-03-20 19:37:26
将此问题分为两部分:
apply map成语创建具有相同位置的列表组:> (apply map list '(((1 2)(3 4)(5 6))((7 8)(9 10)(11 12))))
'(((1 2) (7 8)) ((3 4) (9 10)) ((5 6) (11 12)))append将组中的所有列表追加到一个列表中:> (map (lambda (group) (apply append group))
'(((1 2) (7 8)) ((3 4) (9 10)) ((5 6) (11 12))))
'((1 2 7 8) (3 4 9 10) (5 6 11 12))然后将这两部分合并成一个函数:
(define (iter10 lst)
(map (lambda (group) (apply append group))
(apply map list lst)))测试:
> (iter10 '(((1 2)(3 4)(5 6))((7 8)(9 10)(11 12))))
'((1 2 7 8) (3 4 9 10) (5 6 11 12))
> (iter10 '(((1 2)(3 4)(5 6))((7 8)(9 10)(11 12))((1 2)(3 4)(5 6))))
'((1 2 7 8 1 2) (3 4 9 10 3 4) (5 6 11 12 5 6))https://stackoverflow.com/questions/71549763
复制相似问题