球拍列表中的附加项目
Addition items in list Racket
我正在使用 Racket 中的列表,并且正在执行添加项目的功能。
我做到了
(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,但我不知道该怎么做。
有一个主列表,其中有几个列表。我希望所有元素都按位置连接。并且主列表的数量可以是任意的。谢谢
把这个问题分成两部分:
- 使用
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))
我正在使用 Racket 中的列表,并且正在执行添加项目的功能。 我做到了
(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,但我不知道该怎么做。 有一个主列表,其中有几个列表。我希望所有元素都按位置连接。并且主列表的数量可以是任意的。谢谢
把这个问题分成两部分:
- 使用
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))