結果

問題 No.713 素数の和
ユーザー stmtk_01stmtk_01
提出日時 2018-07-16 19:00:28
言語 Haskell
(9.8.2)
結果
AC  
実行時間 6 ms / 2,000 ms
コード長 615 bytes
コンパイル時間 8,003 ms
コンパイル使用メモリ 162,996 KB
実行使用メモリ 8,232 KB
最終ジャッジ日時 2023-08-13 12:52:31
合計ジャッジ時間 2,011 ms
ジャッジサーバーID
(参考情報)
judge15 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 5 ms
8,224 KB
testcase_01 AC 3 ms
6,896 KB
testcase_02 AC 3 ms
6,956 KB
testcase_03 AC 4 ms
7,396 KB
testcase_04 AC 6 ms
8,232 KB
testcase_05 AC 3 ms
7,192 KB
testcase_06 AC 2 ms
6,868 KB
testcase_07 AC 2 ms
6,960 KB
testcase_08 AC 3 ms
7,216 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.6.1/environments/default
[1 of 2] Compiling Main             ( Main.hs, Main.o )
[2 of 2] Linking a.out

ソースコード

diff #

import Control.Applicative
import Data.List
import Data.Char

getInt :: IO Integer
getInt = (\a -> read a :: Integer) <$> getLine

getIntArray :: IO [Integer]
getIntArray = ((map (\a -> read a :: Integer)) . words) <$> getLine

getStrArray :: Integer -> IO [String]
getStrArray 0 = return [] :: IO [String]
getStrArray n = (:) <$> getLine <*> (getStrArray (n - 1))

getPrime :: Integer -> [Integer]
getPrime 1 = []
getPrime 2 = [2]
getPrime n = 
    let primes = getPrime $ n - 1
    in if all (\a -> mod n a /= 0) primes then (n : primes) else primes

main = do
    print =<< ((foldr (+) 0) . getPrime) <$> getInt
0