1. paizaラーニングトップ
  2. レベルアップ問題集
  3. 素数メニュー(言語選択)
  4. 問題一覧 Clojure(Beta)編
  5. フェルマーテスト Clojure(Beta)編

素数メニューのサムネイル
フェルマーテスト Clojure(Beta)編(paizaランク C 相当)

問題にチャレンジして、ユーザー同士で解答を教え合ったり、コードを公開してみよう!

問題

下記の問題をプログラミングしてみよう!

整数 N が素数であるかを高確率で判定する方法の 1 つとしてフェルマーテストがあります。
整数 N をフェルマーテストで素数判定するときの手順は次の通りです。

1. a を 2 から N-1 までの数からランダムに選ぶ。
2. N が a で割り切れる場合は N は素数でないと判定する。
3. a^(N-1) を N で割ったあまりが 1 ならば N は素数、1 でない場合は素数でないと判定する。


整数 N が与えられるので、 N が素数かどうかをフェルマーテストを用いて判定してください。
なお、今回の問題では、フェルマーテストの手順 1 の a は 2 で固定するものとします。
なお、「整数 N が素数である」とは「N が 1 でない、かつ、N の約数が 1 と N のみしか存在しない」ことをいいます。




ヒント
a^(N-1) を N で割ったあまりを求めるには、1 で初期化した変数 fermat を用意し、次の操作を N-1 回繰り返せば良いです。

1. fermat に a を掛ける。
2. fermat に 「fermat を N で割った余り」 を代入する。

入力される値

N


・ 1 行で整数 N が与えられます。


入力値最終行の末尾に改行が1つ入ります。
文字列は標準入力から渡されます。 標準入力からの値取得方法はこちらをご確認ください
期待する出力

フェルマーテストの結果、N が素数であると判定された場合は "YES" を、そうでない場合は "NO" を 1 行で出力してください。
出力の末尾には改行を入れてください。

条件

・ 3 ≦ N ≦ 100,000

入力例1

3

出力例1

YES

入力例2

837

出力例2

NO

問題一覧へ戻る

ページの先頭へ戻る