開発環境
- 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 コメント:
コメントを投稿