結果

問題 No.3127 Multiple of Twin Prime
ユーザー Meso Meso
提出日時 2025-07-29 11:37:03
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
RE  
実行時間 -
コード長 758 bytes
コンパイル時間 295 ms
コンパイル使用メモリ 12,416 KB
実行使用メモリ 14,416 KB
最終ジャッジ日時 2025-07-29 11:37:07
合計ジャッジ時間 3,488 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample RE * 1
other AC * 2 RE * 10
権限があれば一括ダウンロードができます

ソースコード

diff #

def eratosthenes(n):
    primes = [True] * (n+1)
    primes[0], primes[1] = False, False
    for i in range(2, int(n**0.5)+1):
        if primes[i]:
            for j in range(i*i, n+1, i):
                primes[j] = False

    twins = []
    for i in range(2, n - 1):
        if primes[i] and primes[i+2]:
            twins.append(i)

    return twins

t = int(input())
for _ in range(t):
    n = int(input())
    primes_list = list(eratosthenes(n))

    ok, ng = -1, len(primes_list)
    while abs(ok - ng) > 1:
        mid = (ok + ng) // 2
        p = primes_list[mid]
        if p * (p + 2) <= n:
            ok = mid
        else:
            ng = mid

    if ok == -1:
        print(-1)
    else:
        print(primes_list[ok] * (primes_list[ok] + 2))
0