Сортировка групп по карте и накопление в схеме - PullRequest
0 голосов
/ 10 декабря 2010

Я пытаюсь использовать функции «карта» и «накапливать» в схеме для сортировки неизвестного количества списков в списки, которые первыми будут занимать все первые места списков старых и т. Д.

(1 2 3.. ) (4 5 6..) (7 8 9..)...

к этому списку:

(1 4 7) (2 5 8) (3 6 9).

Я писал это:

(accumulate (lambda (x y) (if  (null? y) x (map cons x y))) null '((1 2 3) (4 5 6) (7 8 9) (9 10 11) (12 13 14)))

, и это продолжает давать мне надоедливую точку в конце ...

((1 4 7 9 . 12) (2 5 8 10 . 13) (3 6 9 11 . 14)).

в чем проблема?спасибо!

Ответы [ 2 ]

0 голосов
/ 11 декабря 2010
(define (accumulate x . rest)
  (append (list x) rest))

> (map accumulate '(1 2 3) '(4 5 6) '(7 8 9))
=> ((1 4 7) (2 5 8) (3 6 9))
> (map accumulate '(1 2 3 4) '(5 6 7 8) '(9 10 11 12) '(13 14 15 16))
=> ((1 5 9 13) (2 6 10 14) (3 7 11 15) (4 8 12 16))
0 голосов
/ 10 декабря 2010

Попробуйте это:

(if (null? y)
    (map list x)
    (map cons x y))
...