結果
問題 |
No.637 X: Yet Another FizzBuzz Problem
|
ユーザー |
|
提出日時 | 2018-01-26 22:28:59 |
言語 | Haskell (9.10.1) |
結果 |
AC
|
実行時間 | 2 ms / 1,000 ms |
コード長 | 699 bytes |
コンパイル時間 | 7,301 ms |
コンパイル使用メモリ | 181,164 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-28 18:48:40 |
合計ジャッジ時間 | 8,054 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 30 |
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.8.2/environments/default [1 of 2] Compiling Main ( Main.hs, Main.o ) [2 of 2] Linking a.out
ソースコード
import Control.Applicative ((<$>)) import Data.ByteString.Char8 (ByteString) import qualified Data.ByteString.Char8 as B import Data.List import Data.Char (isSpace) main :: IO () main = do solve <$> getl (readil B.readInt) >>= print fizzbuzz :: Int -> Int fizzbuzz x | x `mod` 15 == 0 = 8 | x `mod` 3 == 0 = 4 | x `mod` 5 == 0 = 4 | otherwise = (length . show) x solve :: [Int] -> Int solve = sum . map fizzbuzz getl :: (ByteString -> a) -> IO a getl f = f <$> B.getLine readil :: Integral a => (ByteString -> Maybe (a, ByteString)) -> ByteString -> [a] readil f = unfoldr g where g s = do (n, s') <- f s return (n, B.dropWhile isSpace s')