Hatena::Groupcadr

わだばLisperになる このページをアンテナに追加 RSSフィード

2004 | 12 |
2005 | 01 | 02 | 07 | 10 | 11 |
2006 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2007 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2008 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2009 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2010 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2011 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 11 |

2007-02-01

L-99 (15)

| 22:18 | L-99 (15) - わだばLisperになる を含むブックマーク はてなブックマーク - L-99 (15) - わだばLisperになる

L-99 15問目に挑戦 - L-99:Ninety-Nine Lisp Problems

P15

;;; Common Lisp
(defun repli (list n)
  (do ((l list (cdr l))
       (retlist '() `(,@retlist ,@(make-list n :initial-element (car l)))))
      ((endp l) retlist)))

;;; Scheme
(define repli
  (lambda (ls n)
    (let loop ((l ls) (r '()))
      (if (null? l)
          r
          (loop (cdr l)
                `(,@r ,@(make-list n (car l))))))))

make-listが使えそうだったので使ってみた。

ゲスト



トラックバック - http://cadr.g.hatena.ne.jp/g000001/20070201