結果
問題 |
No.36 素数が嫌い!
|
ユーザー |
|
提出日時 | 2021-06-10 04:22:34 |
言語 | OCaml (5.2.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 864 bytes |
コンパイル時間 | 829 ms |
コンパイル使用メモリ | 19,820 KB |
実行使用メモリ | 26,112 KB |
最終ジャッジ日時 | 2024-11-29 07:51:38 |
合計ジャッジ時間 | 134,165 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 TLE * 1 |
other | AC * 4 WA * 2 TLE * 20 |
ソースコード
module FMath = struct let is_prime n = if n < 2 then false else if n = 2 then true else if ((n mod 2) = 0) then false else let sqrt_n = (int_of_float (sqrt (float_of_int n)) + 1) in let rec rec_is_prime p = let p2_1 = (p * 2) + 1 in if (p2_1 > sqrt_n) then true else if ((n mod p2_1) = 0) then false else rec_is_prime (p + 1) in rec_is_prime 1;; let primes limit = let rec acc n result = if (n = limit) then result else if (is_prime n) then acc (n + 1) (n :: result) else acc (n + 1) result in acc 2 [];; end let () = let n = read_int () in (if n = 1 then "NO" else if FMath.is_prime n then "NO" else if FMath.primes n |> List.map (fun x -> x mod n = 0) |> List.fold_left (||) false then "NO" else "YES") |> print_string; print_newline ();;