開発環境
- 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(著)長尾 高弘(翻訳))の9章(集合と辞書)、9.5(練習問題)、6.をHaskellで解いてみる。
その他参考書籍
- プログラミングHaskell (オーム社) Graham Hutton(著) 山本 和彦(翻訳)
- Real World Haskell―実戦で学ぶ関数型言語プログラミング (オライリージャパン) Bryan O'Sullivan John Goerzen Don Stewart(著) 山下 伸夫 伊東 勝利 株式会社タイムインターメディア(翻訳)
9.5(練習問題)、6.
コード(BBEdit)
Sample.hs
{-# OPTIONS -Wall -Werror #-}
import qualified Data.Map as Map
main :: IO ()
main = do
putStrLn $ "特定の種類の素粒子を検出する確率を示すMap: " ++
show elementaryParticles
putStrLn $ "最も確率の低い素粒子: " ++ (show $ minElementaryParticles
elementaryParticles)
minElementaryParticles :: (Ord a) => Map.Map k a -> k
minElementaryParticles m = fst $
foldr1 (\(k, a) (l, b) -> if a < b then
(k, a)
else
(l, b)) $ Map.toList m
elementaryParticles :: Map.Map String Double
elementaryParticles = Map.fromList [("ニュートロン", 0.55), ("陽子", 0.21),
("中間子", 0.03), ("ミューオン", 0.07), ("ニュートリノ", 0.14)]
入出力結果(Terminal, runghc)
$ runghc Sample.hs
特定の種類の素粒子を検出する確率を示すMap: fromList [("\12491\12517\12540\12488\12522\12494",0.14),("\12491\12517\12540\12488\12525\12531",0.55),("\12511\12517\12540\12458\12531",7.0e-2),("\20013\38291\23376",3.0e-2),("\38525\23376",0.21)]
最も確率の低い素粒子: "\20013\38291\23376"
$
{-# OPTIONS -Wall -Werror #-}を記述してるから、細かく型を指定(:: Double)しないと警告がいっぱい出た。慣れるまでは{-# OPTIONS -Wall -Werror #-}の記述を消さずに細かく型を指定していくことに。
0 コメント:
コメントを投稿