match式によるパターンマッチを function構文で書くことができる。パターンマッチのための仮引数が現れないのがミソ。
# let rec sum_list = function [] -> 0 | hd::tl -> hd + sum_list tl ;; val sum_list : int list -> int = <fun> # sum_list [1;2;3;4;5;6;7;8;9;10];; - : int = 55
takatoh's blog – Learning programming languages.
match式によるパターンマッチを function構文で書くことができる。パターンマッチのための仮引数が現れないのがミソ。
# let rec sum_list = function [] -> 0 | hd::tl -> hd + sum_list tl ;; val sum_list : int list -> int = <fun> # sum_list [1;2;3;4;5;6;7;8;9;10];; - : int = 55
List.map はリストの各要素に関数を適用する。
# List.map (fun x -> x * x) [1;2;3;4;5];; - : int list = [1; 4; 9; 16; 25]
実装してみる。
# let rec map' f l = match l with [] -> [] | hd::tl -> f hd :: map' f tl ;; val map' : ('a -> 'b) -> 'a list -> 'b list = <fun> # map' (fun x -> x * 10) [1;2;3;4;5];; - : int list = [10; 20; 30; 40; 50]
function構文を使って,
# let rec map'' f = function [] -> [] | hd::tl -> f hd :: map'' f tl ;; val map'' : ('a -> 'b) -> 'a list -> 'b list = <fun> # map'' (fun x -> x * 10) [1;2;3;4;5];; - : int list = [10; 20; 30; 40; 50]
List.fold_left は左から,List.fold_right は右からたたみ込む。
# List.fold_left (fun x y -> "(" ^ x ^ "," ^ y ^ ")") "A" ["B";"C";"D"];; - : string = "(((A,B),C),D)" # List.fold_right (fun x y -> "(" ^ x ^ "," ^ y ^ ")") ["A";"B";"C"] "D";; - : string = "(A,(B,(C,D)))"
引数の順番が違うので,ちょっと注意が必要。
# List.fold_left;; - : ('a -> 'b -> 'a) -> 'a -> 'b list -> 'a = <fun> # List.fold_right;; - : ('a -> 'b -> 'b) -> 'a list -> 'b -> 'b = <fun>