I can't see why the second code doesn't work like the first:

(use-modules (srfi srfi-1))
(define D '(((3 4))))
(let ((r 1))
       (set! D (append D '(())))
       (display D)(newline)
       (set-car! (drop D r) (car (drop D (- r 1)))))
(let ((r 2))
       (set! D (append D '(())))
       (display D)(newline)
       (set-car! (drop D r) (car (drop D (- r 1)))))
output:
(((3 4)) ())
(((3 4)) ((3 4)) ())

(use-modules (srfi srfi-1))
(define D '(((3 4))))
(map (lambda (r)
       (set! D (append D '(())))
       (display D)(newline)
       (set-car! (drop D r) (car (drop D (- r 1)))))
     '(1 2))
output:
(((3 4)) ())
(((3 4)) ((3 4)) ((3 4)))

guile (GNU Guile) 2.0.11
i686-pc-linux-gnu



Reply via email to