blog/content/post/2008/10/09/2008-10-09-00001049.md

5.3 KiB

title author date wordtwit_post_info categories
高階関数の練習をするよ kazu634 2008-10-09
O:8:"stdClass":13:{s:6:"manual";b:0;s:11:"tweet_times";i:1;s:5:"delay";i:0;s:7:"enabled";i:1;s:10:"separation";s:2:"60";s:7:"version";s:3:"3.7";s:14:"tweet_template";b:0;s:6:"status";i:2;s:6:"result";a:0:{}s:13:"tweet_counter";i:2;s:13:"tweet_log_ids";a:1:{i:0;i:4329;}s:9:"hash_tags";a:0:{}s:8:"accounts";a:1:{i:0;s:7:"kazu634";}}
gauche
Lisp

ちょっと前に自分なりにmaxを定義してみました。同じようにすれば、minも定義できます。

(define (max-number lis)
(fold
(lambda (a b)
(if (< a b)
b
a))
(car lis) (cdr lis)))
(define (my_max . args)
(max-number args))
(define (min-number lis)
(fold
(lambda (a b)
(if (> a b)
b
a))
(car lis) (cdr lis)))
(define (my_min . args)
(min-number args))

この中から共通の構造を抜き出して、中間的な手続きを作成してみます。この中間的な手続きは「<」や「>」を受け取って、「引数を一つ取る手続き」を戻り値とします。

(define (pickup proc)
(lambda (lis)
(fold
(lambda (a b)
(if (proc a b)
b
a))
(car lis) (cdr lis))))

これを使うと、

gosh> (define (my_max . args)
((pickup <) args))
my_max
gosh> (my_max 1 2 3 4 5 6 7)
7
gosh> (define (my_min . args)
((pickup >) args))
my_min
gosh> (my_min 1 2 3 4 5 6  34)

というような書き方になります。

感想: だいぶ理解してきた気がする。