2013年11月28日木曜日

開発環境

初めてのコンピュータサイエンス(Jennifer CampbellPaul GriesJason MontojoGreg Wilson(著)長尾 高弘(翻訳))の9章(集合と辞書)、9.5(練習問題)、11.をHaskellで解いてみる。

その他参考書籍

9.5(練習問題)、11.

コード(BBEdit)

Sample.hs

{-# OPTIONS -Wall -Werror #-}
import qualified Data.Map as Map
import qualified Data.Set as Set

main :: IO ()
main = print $ dbHeadings scientists

dbHeadings :: (Ord k) => Map.Map k (Map.Map k a) -> Set.Set k
dbHeadings m = foldr (\x s -> Set.union s $ Set.fromList $ Map.keys x)
                     (Set.fromList []) $
                     Map.elems m

scientists :: Map.Map String (Map.Map String String)
scientists = Map.fromList $
    [("jグドール", Map.fromList $
         [("forename", "グドール"), ("surname", "ジェーン"), ("born", "1934"), ("died", ""),
          ("notes", "霊長類研究者"),
          ("author", "In the shadow of man, The Chimpanzees of Combe")]),
     ("Rフランクリン", Map.fromList $
         [("forename", "フランクリン"), ("surname", "ロザリンド"), ("born", "1920"),
          ("died", "1957"), ("notes", "DNAの発見に貢献")]),
     ("Rカーソン", Map.fromList $
         [("forename", "カーソン"), ("surname", "レイチェル"), ("born", "1907"),
          ("died", "1964"), ("notes", "DDTの害毒に注意を喚起"),
          ("author", "沈黙の春")])]

入出力結果(Terminal, runghc)

$ runghc Sample.hs
fromList ["author","born","died","forename","notes","surname"]
$

{-# OPTIONS -Wall -Werror #-}を記述してるから、細かく型を指定(:: Double)しないと警告がいっぱい出た。慣れるまでは{-# OPTIONS -Wall -Werror #-}の記述を消さずに細かく型を指定していくことに。

0 コメント:

コメントを投稿