[Haskell]バナナスプリット則 part1

やりたいこと

以下のバナナスプリット則の例を実装したい。
・(|f|),(|g|)・=(|・f”F(π1),g”F(π2)・|)

スクリプト

Haskellでfoldrの結果をタプルで出力させるための文法が分からなくて、
Google先生も教えてくれなかったので今日は断念した。 あとは、以下のAfterの部分を1つのfoldrにまとめることができればバナナストリップ則の具体例の実装が出来る。
-- Before
sum' = foldr (\x xs -> x + xs) 0
length' = foldr (\x n -> 1 + n) 0
average ls = sum' ls / length' ls

-- After
average' ls = s / l
    where
        (s, l) = ((foldr (\x xs -> x + xs) 0) ls, (foldr (\x n -> 1 + n) 0) ls)

実行結果

途中経過だけど実行してみる。
$ghci
Prelude> :load banana-strip.hs
Main> average' [1,2,3,4,5]
3.0
zuqqhi2

某Web系の会社でエンジニアをやっています。 学術的なことに非常に興味があります。 趣味は楽器演奏、ジョギング、読書、料理などなど手広くやっています。

Share
Published by
zuqqhi2
Tags: haskell