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-08

L-99 (4)

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

引き続き今回もL-99:Ninety-Nine Lisp Problems

70年代のLispのソースを参考に意味無くPROGを使ってみ

ています。

P04

解答
;; Common Lisp
(DEFUN NUMBER-OF-ELEMENTS (LIST)
  (PROG (N L)
	(SETQ N 0)
	(SETQ L LIST)
L	(COND ((NULL L) (GO X)))
        (PSETQ N (1+ N)
	       L (CDR L))
	(GO L)
X	(RETURN N)))

;; Scheme
(define number-of-element 
  (lambda (ls)
    (if (null? ls)
	0
	(+ 1 (number-of-element (cdr ls))))))

ゲスト



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