2014年1月17日金曜日

開発環境

Real World Haskell―実戦で学ぶ関数型言語プログラミング(Bryan O'Sullivan (著)、 John Goerzen (著)、 Don Stewart (著)、山下 伸夫 (翻訳)、伊東 勝利 (翻訳)、株式会社タイムインターメディア (翻訳)、オライリージャパン)の3章(型を定義し、関数を単純化する)、3.13(ガードの条件節の評価)、練習問題5.を解いてみる。

その他参考書籍

練習問題5.

コード(BBEdit)

Sample.hs

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

isPalindrome :: (Eq a) => [a] -> Bool
isPalindrome [] = True
isPalindrome (x:y:[]) = x == y
isPalindrome (_:_:_:[]) = False
isPalindrome (x:xs) = x == last xs && isPalindrome (take (length xs - 1) xs)

a :: [Int]
a = [1, 2, 3]

b :: [Int]
b = palindrome a

c :: String
c = "Haskell"

d :: String
d = palindrome c

e :: [a]
e = []

f :: [Char]
f = ""

g :: [Int]
g = [1,2,3,4,5,4,3,2,1]

入出力結果(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 Sample
[1 of 1] Compiling Main             ( Sample.hs, interpreted )
Ok, modules loaded: Main.
*Main> isPalindrome a
False
*Main> isPalindrome b
True
*Main> isPalindrome c
False
*Main> isPalindrome d
True
*Main> isPalindrome e
True
*Main> isPalindrome f
True
*Main> isPalindrome g
False
*Main> :quit 
Leaving GHCi.
$

0 コメント:

コメントを投稿