結果
| 問題 | No.12 限定された素数 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-02-05 02:45:23 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 343 ms / 5,000 ms |
| コード長 | 676 bytes |
| 記録 | |
| コンパイル時間 | 1,530 ms |
| コンパイル使用メモリ | 82,392 KB |
| 実行使用メモリ | 123,596 KB |
| 最終ジャッジ日時 | 2025-02-07 08:44:16 |
| 合計ジャッジ時間 | 10,678 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 26 |
ソースコード
# ref http://yukicoder.me/submissions/3957
import math
def prime(max):
max2 = (max-3)//2
sieve = [True]*(max2+1)
for i in range(int((math.sqrt(max)-3)/2)+1):
if not sieve[i]: continue
k = i+i+3
j = k*(i+1)+i
while j <= max2:
sieve[j] = False
j += k
sieve = [2]+[i+i+3 for i in range(max2+1) if sieve[i]]
return sieve
input()
a=set(input().split())
max=5000000
start=1
rest=a
ans=-1
for i in prime(max):
l=set(str(i))
if len(l-a):
if len(rest)==0 and ans<i-1-start: ans=i-1-start
start=i+1
rest=a
else:
rest=rest-l
if len(rest)==0 and ans<max-start: ans=max-start
print(ans)