計算機科学のブログ

Haskell - コンテキストでの型の操作 - Monad型クラス - Applicativeよりも強力であることの証明

入門Haskellプログラミング (Will Kurt(著)、株式会社クイープ(監修、翻訳)、翔泳社)の UNIT5(コンテキストでの型の操作)、LESSON 30(Monad型クラス)、30.5(練習問題)、Q30-2の解答を求めてみる。

コード

sample.hs

main :: IO ()
main = do
  print $ allApp (Just show) (Just 1)

allApp :: (Monad m) => m (a -> b) -> m a -> m b
allApp f x = f >>= (\g -> x >>= (\y -> return (g y)))

入出力結果(Terminal, Zsh)

% runghc sample.hs
Just "1"
%