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

.1

| 23:10 | .1 - わだばLisperになる を含むブックマーク はてなブックマーク - .1 - わだばLisperになる

自分も「どう書く?org」に参加してみたくなってアカ

ウントを作成してみた。しかし自分の解けそうな問題が

あまりない…。

投稿するにはなんとなく旬を過ぎてしまったので、ここ

に載せてみるのだった…。

;; ================================================================
;; 隣り合う二項の差
;; ================================================================
(defun diff (list)
  (mapcar #'- (cdr list) list))

(defun diff (list)
  (do ((l list (cdr l))
       (r () (cons (- (cadr l) (car l)) r)))
      ((endp (cdr l)) (nreverse r))))

;; ================================================================
;;重複無し乱数リスト
;; ================================================================
(defun bingo (n)
  (let ((l (loop for i from 1 to n collect i)))
    (dotimes (i n l)
      (rotatef (nth i l) (nth (random n) l)))))

;; ================================================================
;; ビンゴの結果を整形表示 
;; ================================================================
(defun format-bingo (n)
  (let* ((keta (1+ (truncate (log n 10))))
	 (fstr (format nil "~{~A~}" (list "~{~" (1+ keta) "@A~}~%" 
					  "~{~" (1+ keta) "@A~}~%~%"))))
    (do ((cnt n (- cnt 10))
	 (l (bingo n) (nthcdr 10 l))
	 (idx (loop for i from 1 to n collect i) (nthcdr 10 idx)))
	((endp l))
      (if (<= 10 cnt)
	  (format t fstr (subseq idx 0 10) (subseq l 0 10))
	  (format t fstr idx l)))))

ゲスト



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