2014年1月24日金曜日

開発環境

Real World Haskell―実戦で学ぶ関数型言語プログラミング(Bryan O'Sullivan (著)、 John Goerzen (著)、 Don Stewart (著)、山下 伸夫 (翻訳)、伊東 勝利 (翻訳)、株式会社タイムインターメディア (翻訳)、オライリージャパン)の4章(関数プログラミング)、4.5(リストを使う)、練習問題 1.を解いてみる。

その他参考書籍

練習問題 1.

コード(BBEdit, Emacs)

Sample.hs

{-# OPTIONS -Wall -Werror #-}
module SafeList where

safeHead :: [a] -> Maybe a
safeHead xs = if null xs then Nothing else Just (head xs)

safeTail :: [a] -> Maybe [a]
safeTail xs = if null xs then Nothing else Just (tail xs)

safeLast :: [a] -> Maybe a
safeLast xs = if null xs then Nothing else Just (last xs)

safeInit :: [a] -> Maybe [a]
safeInit xs = if null xs then Nothing else Just (init xs)

入出力結果(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 SafeList.hs 
[1 of 1] Compiling SafeList         ( SafeList.hs, interpreted )
Ok, modules loaded: SafeList.
*SafeList> let a = [1..5]
*SafeList> let empty = []
*SafeList> safeHead a
Just 1
*SafeList> safeHead empty 
Nothing
*SafeList> safeTail a
Just [2,3,4,5]
*SafeList> safeTail e
either          encodeFloat     enumFromThenTo  even
elem            enumFrom        enumFromTo      exp
empty           enumFromThen    error           exponent
*SafeList> safeTail empty 
Nothing
*SafeList> safeLast a
Just 5
*SafeList> safeLast empty 
Nothing
*SafeList> safeInit a
Just [1,2,3,4]
*SafeList> safeInit empty
Nothing
*SafeList> :quit 
Leaving GHCi.
$

0 コメント:

コメントを投稿