開発環境
- OS X Mavericks - Apple(OS)
- Emacs (CUI)、BBEdit - Bare Bones Software, Inc. (GUI) (Text Editor)
- Scheme (プログラミング言語)
- Gauche (処理系)
プログラミングGauche(Kahuaプロジェクト (著)、 川合 史朗 (監修)、オライリージャパン)の第3部(実用的なプログラミング)、9章(状態の管理)、9.1(集合)、delete手続きを書いてみる。
その他参考書籍
- Scheme手習い(Daniel P. Friedman (著), Matthias Felleisen (著), 元吉 文男 (翻訳), 横山 晶一 (翻訳), オーム社)
- 計算機プログラムの構造と解釈(Gerald Jay Sussman(原著)、Julie Sussman(原著)、Harold Abelson(原著)、和田 英一(翻訳)、ピアソンエデュケーション、原書: Structure and Interpretation of Computer Programs (MIT Electrical Engineering and Computer Science)(SICP))
- Instructor's Manual to Accompany Structure & Interpretation of Computer Programs
delete手続き
コード(BBEdit, Emacs)
sample.scm
#!/usr/bin/env gosh ;; -*- coding: utf-8 -*- ;; これまでに書いた手続き (load "./procedures.scm") (define (delete elt lis . options) (let-optionals* options ((cmp-fn equal?)) (define (loop lis) (cond ((null? lis) '()) ((cmp-fn elt (car lis)) (loop (cdr lis))) (else (cons (car lis) (loop (cdr lis)))))) (loop lis))) (for-each (lambda (lis) (for-each print (list (delete-1 2 lis) (delete 2 lis)))) (list (list 1 2 3 4 5 1 2 3 4 5) (list 2 1 3 4 5 1 3 4 5 2) (list 1 2 2 3 4 5) (list) (list 2 2 3 4 5) (list 3 4 5 2 2)))
入出力結果(Terminal(gosh), REPL(Read, Eval, Print, Loop))
$ ./sample.scm (1 3 4 5 1 2 3 4 5) (1 3 4 5 1 3 4 5) (1 3 4 5 1 3 4 5 2) (1 3 4 5 1 3 4 5) (1 2 3 4 5) (1 3 4 5) () () (2 3 4 5) (3 4 5) (3 4 5 2) (3 4 5) $
0 コメント:
コメントを投稿