開発環境
- OS X Mavericks - Apple(OS)
- BBEdit - Bare Bones Software, Inc., Emacs (Text Editor)
- Haskell (純粋関数型プログラミング言語)
- GHC (The Glasgow Haskell Compiler) (処理系)
- The Haskell Platform (インストール方法、モジュール等)
初めてのコンピュータサイエンス(Jennifer Campbell、Paul Gries、Jason Montojo、Greg Wilson(著)長尾 高弘(翻訳))の12章(各種ツール)、12.7(練習問題)、12-10.をHaskellで解いてみる。
その他参考書籍
- プログラミングHaskell (オーム社) Graham Hutton(著) 山本 和彦(翻訳)
- Real World Haskell―実戦で学ぶ関数型言語プログラミング (オライリージャパン) Bryan O'Sullivan John Goerzen Don Stewart(著) 山下 伸夫 伊東 勝利 株式会社タイムインターメディア(翻訳)
12.7(練習問題)、12-10.
コード(BBEdit)
Sample.hs
{-# OPTIONS -Wall -Werror #-} import Data.List main :: IO () main = mapM_ putStrLn $ map (\(a, b, c) -> if isSorted b == c then show True else show False ++ a) testLists isSorted :: (Ord a) => [a] -> Bool isSorted ns = ns == sort ns testLists :: [(String, [Int], Bool)] testLists = [("空のリスト", [], True), ("要素が1つのリスト", [10], True), ("要素が2つのソート済リスト", [1, 2], True), ("要素が2つの逆順リスト", [2, 1], False), ("全て等しいよそのリスト", [10, 10], True), ("先頭がソートされてないリスト", [10, 1, 2, 3, 4], False), ("真ん中がソートされていないリスト", [1, 2, 10, 4, 5], False), ("末尾がソートされていないリスト", [1, 2, 3, 4, 0], False)]
入出力結果(Terminal, runghc)
$ runghc Sample.hs True True True True True True True True $
慣れるまでは{-# OPTIONS -Wall -Werror #-}の記述を消さずに細かく型を指定していくことに。
0 コメント:
コメントを投稿