結果
| 問題 |
No.36 素数が嫌い!
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-06-10 04:15:03 |
| 言語 | OCaml (5.2.1) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 755 bytes |
| コンパイル時間 | 2,016 ms |
| コンパイル使用メモリ | 19,440 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-11-29 07:41:59 |
| 合計ジャッジ時間 | 3,176 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 WA * 3 |
| other | AC * 9 WA * 17 |
ソースコード
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 "YES"
else "NO") |> print_string;
print_newline ();;