結果
| 問題 |
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 ();;