結果
問題 |
No.312 置換処理
|
ユーザー |
![]() |
提出日時 | 2015-12-05 16:50:18 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 359 bytes |
コンパイル時間 | 375 ms |
コンパイル使用メモリ | 81,920 KB |
実行使用メモリ | 64,512 KB |
最終ジャッジ日時 | 2024-09-14 14:27:17 |
合計ジャッジ時間 | 3,953 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 1 TLE * 1 -- * 43 |
ソースコード
import random as s def p(q,k=50): if n%2==0:return 0 d=(q-1)>>1 while d&1==0:d>>=1 while k: k-=1 t=d y=pow(s.randint(1,q-1),t,q) while t!=q-1 and y!=1 and y!=q-1: y=pow(y,2,q) t<<=1 if y!=q-1 and t&1==0:return 0 return 1 n=int(input()) if p(n): print(n) else: for i in range(3,n//2+1): if n%i==0: print(i) break else:print(n)