2014年1月20日月曜日

開発環境

Real World Haskell―実戦で学ぶ関数型言語プログラミング(Bryan O'Sullivan (著)、 John Goerzen (著)、 Don Stewart (著)、山下 伸夫 (翻訳)、伊東 勝利 (翻訳)、株式会社タイムインターメディア (翻訳)、オライリージャパン)の3章(型を定義し、関数を単純化する)、3.13(ガードの条件節の評価)、練習問題8.を解いてみる。

その他参考書籍

練習問題8.

コード(BBEdit)

ch03/Intersperse.hs

{-# OPTIONS -Wall -Werror #-}
-- ch03/Tree.hs

data Tree a = Empty | Node a (Tree a) (Tree a)
              deriving (Show)

height :: Tree a -> Int
height Empty = 0
height (Node _ Empty Empty) = 1
height (Node _ left right)
    | height left > height right = 1 + height left
    | otherwise = 1 + height right

入出力結果(Terminal, インタプリタghci)

$ ghci
GHCi, version 7.6.3: http://www.haskell.org/ghc/  :? for help
Loading package ghc-prim ... linking ... done.
Loading package integer-gmp ... linking ... done.
Loading package base ... linking ... done.
Prelude> :load Tree
[1 of 1] Compiling Main             ( Tree.hs, interpreted )
Ok, modules loaded: Main.
*Main> height Empty
0
*Main> height (Node "x" Empty Empty)
1
*Main> height (Node "x" Empty (Node "y" Empty Empty))
2
*Main> :quit
Leaving GHCi.
$

0 コメント:

コメントを投稿