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-01-04

L-99 (3)

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

今回もL-99: Ninety-Nine Lisp Problems

P03

解答:
;; Common Lisp
(DEFUN ELEMENT-AT (LIST K)
  (PROG (L C)
        (SETQ L LIST
              C K)
L       (AND (= C 1) (GO X))
        (PSETQ C (1- C)
               L (CDR L))
        (GO L)
X       (RETURN (CAR L))))

;; Scheme
(define element-at
  (lambda (ls k)
    (if (= k 1)
        (car ls)
        (element-at (cdr ls) (- k 1)))))

ゲスト



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