SICP Exercise 2.36 accumulate-n

Exercise 2.36.  The procedure accumulate-n is similar to accumulate except that it takes as its third argument a sequence of sequences, which are all assumed to have the same number of elements. It applies the designated accumulation procedure to combine all the first elements of the sequences, all the second elements of the sequences, and so on, and returns a sequence of the results. For instance, if s is a sequence containing four sequences, ((1 2 3) (4 5 6) (7 8 9) (10 11 12)), then the value of (accumulate-n + 0 s) should be the sequence (22 26 30). Fill in the missing expressions in the following definition of accumulate-n:

(define (accumulate-n op init seqs)
  (if (null? (car seqs))
      nil
      (cons (accumulate op init <??>)
            (accumulate-n op init <??>))))


SOLUTION


The code and tests are here. The test results are also pasted and highlighted below.

; Tests

Welcome to DrRacket, version 6.11 [3m].
Language: racket, with debugging; memory limit: 128 MB.
> (define lol (list (list 1 2 3) (list 4 5 6) (list 7 8 9) (list 10 11 12)))
> lol
'((1 2 3) (4 5 6) (7 8 9) (10 11 12))
> (seqs-without-first-elements lol)
'((2 3) (5 6) (8 9) (11 12))
> (seqs-without-first-elements (seqs-without-first-elements lol))
'((3) (6) (9) (12))
> (seqs-without-first-elements (seqs-without-first-elements (seqs-without-first-elements lol)))
'(() () () ())
> (seqs-without-first-elements (seqs-without-first-elements (seqs-without-first-elements (seqs-without-first-elements lol))))
'(() () () ())
> (seq-of-first-elements lol)
'(1 4 7 10)
> (define small (list (list 3) (list 6) (list 9) (list 12)))
> small
'((3) (6) (9) (12))
> (seq-of-first-elements small)
'(3 6 9 12)
> (seqs-without-first-elements small)
'(() () () ())
> (seq-of-first-elements (seqs-without-first-elements small))
'(() () () ())
> (accumulate-n + 0 lol)
'(22 26 30)
> (seq-of-first-elements (seqs-without-first-elements small))
'(() () () ())
> (accumulate-n + 0 (seq-of-first-elements (seqs-without-first-elements small)))
'()


Comments

Popular posts from this blog

SICP Exercise 4.18 a alternative strategy for interpreting internal definitions

SICP Exercise 3.11 make-account internal definitions with local state

SICP Exercise 3.13 make-cycle