Skip to content

Instantly share code, notes, and snippets.

@pasberth
Created August 7, 2012 21:25
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save pasberth/3289528 to your computer and use it in GitHub Desktop.
Save pasberth/3289528 to your computer and use it in GitHub Desktop.
classの勉強ついでにおめが垢消せ

output:

$ runhaskell omegafb.hs
1 2 Fizz 4 Buzz Fizz 7 8 Fizz Buzz 11 Fizz 13 14 FizzBuzz 16 17 Fizz 19 Buzz Fizz 22 23 Fizz Buzz 26 Fizz 28 29 FizzBuzz 31 32 Fizz 34 Buzz Fizz 37 38 Fizz Buzz 41 Fizz 43 44 FizzBuzz 46 47 Fizz 49 Buzz Fizz 52 53 Fizz Buzz 56 Fizz 58 59 FizzBuzz 61 62 Fizz 64 Buzz Fizz 67 68 Fizz Buzz 71 Fizz 73 74 FizzBuzz 76 77 Fizz 79 Buzz Fizz 82 83 Fizz Buzz 86 Fizz 88 89 FizzBuzz 91 92 Fizz 94 Buzz Fizz 97 98 Fizz Buzz
1 2 おめが 4 垢消せ おめが 7 8 おめが 垢消せ 11 おめが 13 14 おめが垢消せ 16 17 おめが 19 垢消せ おめが 22 23 おめが 垢消せ 26 おめが 28 29 おめが垢消せ 31 32 おめが 34 垢消せ おめが 37 38 おめが 垢消せ 41 おめが 43 44 おめが垢消せ 46 47 おめが 49 垢消せ おめが 52 53 おめが 垢消せ 56 おめが 58 59 おめが垢消せ 61 62 おめが 64 垢消せ おめが 67 68 おめが 垢消せ 71 おめが 73 74 おめが垢消せ 76 77 おめが 79 垢消せ おめが 82 83 おめが 垢消せ 86 おめが 88 89 おめが垢消せ 91 92 おめが 94 垢消せ おめが 97 98 おめが 垢消せ
class FizzBuzz a where
showFizzBuzz :: a -> Int -> String
showFizz :: a -> Int -> String
showBuzz :: a -> Int -> String
showOther :: a -> Int -> String
fizzbuzz :: (FizzBuzz a) => a -> Int -> String
fizzbuzz a x | x `mod` 15 == 0 = showFizzBuzz a x
| x `mod` 3 == 0 = showFizz a x
| x `mod` 5 == 0 = showBuzz a x
| otherwise = showOther a x
data PopularFizzBuzz = PopularFizzBuzz
instance FizzBuzz PopularFizzBuzz where
showFizzBuzz PopularFizzBuzz x = "FizzBuzz"
showFizz PopularFizzBuzz x = "Fizz"
showBuzz PopularFizzBuzz x = "Buzz"
showOther PopularFizzBuzz x = show x
data OmegaAkakese = OmegaAkakese
instance FizzBuzz OmegaAkakese where
showFizzBuzz OmegaAkakese x = "おめが垢消せ"
showFizz OmegaAkakese x = "おめが"
showBuzz OmegaAkakese x = "垢消せ"
showOther OmegaAkakese x = show x
fizzbuzzPopular = fizzbuzz PopularFizzBuzz
fizzbuzzOmegaAkakese = fizzbuzz OmegaAkakese
runFizzBuzz :: (Int -> String) -> [String]
runFizzBuzz f = map f [1..100]
main = do
putStrLn $ unwords $ runFizzBuzz fizzbuzzPopular -- ノーマルなfizzbuzz
putStrLn $ unwords $ runFizzBuzz fizzbuzzOmegaAkakese -- おめが垢消せ
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment