結果

問題 No.12 限定された素数
ユーザー konchanksukonchanksu
提出日時 2020-04-30 02:05:12
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
AC  
実行時間 1,330 ms / 5,000 ms
コード長 803 bytes
コンパイル時間 181 ms
コンパイル使用メモリ 10,880 KB
実行使用メモリ 49,084 KB
最終ジャッジ日時 2023-08-20 17:56:37
合計ジャッジ時間 36,300 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1,268 ms
47,308 KB
testcase_01 AC 1,321 ms
48,880 KB
testcase_02 AC 1,301 ms
47,508 KB
testcase_03 AC 1,310 ms
47,564 KB
testcase_04 AC 1,286 ms
47,612 KB
testcase_05 AC 1,330 ms
47,724 KB
testcase_06 AC 1,311 ms
47,324 KB
testcase_07 AC 1,299 ms
47,408 KB
testcase_08 AC 1,302 ms
49,084 KB
testcase_09 AC 1,281 ms
48,616 KB
testcase_10 AC 1,306 ms
47,312 KB
testcase_11 AC 1,287 ms
48,712 KB
testcase_12 AC 1,295 ms
47,524 KB
testcase_13 AC 1,313 ms
47,508 KB
testcase_14 AC 1,316 ms
47,252 KB
testcase_15 AC 1,324 ms
47,512 KB
testcase_16 AC 1,275 ms
48,736 KB
testcase_17 AC 1,261 ms
47,368 KB
testcase_18 AC 1,261 ms
47,336 KB
testcase_19 AC 1,260 ms
47,588 KB
testcase_20 AC 1,263 ms
47,556 KB
testcase_21 AC 1,300 ms
47,396 KB
testcase_22 AC 1,270 ms
47,660 KB
testcase_23 AC 1,250 ms
47,512 KB
testcase_24 AC 1,294 ms
47,336 KB
testcase_25 AC 1,312 ms
47,552 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

from copy import copy

def prime_num(end):
    prime_list = [True for i in range(end + 1)]
    prime_list[0], prime_list[1] = False, False
    
    for i in range(2, int(end ** 0.5) + 1):
        if not prime_list[i]:
            continue
        for j in range(i * 2, end + 1, i):
            prime_list[j] = False
            
    return (i for i in range(2, end + 1) if prime_list[i])
            
N = int(input())
A = set(input().split())
ans = -1

prime = prime_num(5 * 10 ** 6)
lists = copy(A)
nokori = copy(A)
left = 1

for i in prime:
    tmp = set(str(i))
    if A | tmp != A:
        if not nokori:     
            ans = max(ans, abs(i - left - 1))
        left = i + 1
        nokori = copy(A)
        continue

    nokori -= tmp

print(max(ans, 4999999 - left) if len(A) != 10 else 4999999)
0