開発環境
- OS X Lion - Apple(OS)
- Emacs、BBEdit - Bare Bones Software, Inc. (Text Editor)
- Haskell (純粋関数型プログラミング言語)
- GHC (The Glasgow Haskell Compiler) (処理系)
『初めてのプログラミング 第2版』(Chris Pine 著、長尾 高弘 訳、オライリー・ジャパン、2010年、ISBN978-4-87311-469-9)の12章(新しいクラスのオブジェクト), 12.6(練習問題の続き)、roman_to_integer 'mcmxcix'!をHaskellで解いてみる。
その他参考書籍
- プログラミングHaskell (オーム社) Graham Hutton(著) 山本 和彦(翻訳)
- Real World Haskell―実戦で学ぶ関数型言語プログラミング (オライリージャパン) Bryan O'Sullivan John Goerzen Don Stewart(著) 山下 伸夫 伊東 勝利 株式会社タイムインターメディア(翻訳)
romanToInteger
コード(BBEdit)
sample.hs
{-# OPTIONS -Wall -Werror #-} import qualified Data.Char as Char import qualified Data.Map as Map main :: IO () main = do mapM_ putStrLn $ map (\x -> x ++ ": " ++ (eitherToString $ romanToInteger x)) ["abcde", "mcmxcix", "MCMXCIX"] eitherToString :: Either String Integer -> String eitherToString (Left a) = a eitherToString (Right a) = (show a) romanToInteger :: String -> Either String Integer romanToInteger xs = romanCharToInteger xs 0 0 romanIntMap :: Map.Map Char Integer romanIntMap = Map.fromList $ [('m', 1000), ('d', 500), ('c', 100), ('l', 50), ('x', 10), ('v', 5), ('i', 1)] romanCharToInteger :: String -> Integer -> Integer -> Either String Integer romanCharToInteger [] _ b = Right b romanCharToInteger xs a b = let c = Char.toLower $ last xs d = init xs e = Map.lookup c romanIntMap in case e of Nothing -> Left "有効なローマ数字ではない!" Just f -> if f >= a then romanCharToInteger d f (b + f) else romanCharToInteger d a (b - f)
入出力結果(Terminal, runghc)
$ runghc sample.hs abcde: 有効なローマ数字ではない! mcmxcix: 1999 MCMXCIX: 1999 $
0 コメント:
コメントを投稿