結果
問題 |
No.3127 Multiple of Twin Prime
|
ユーザー |
|
提出日時 | 2025-07-29 11:37:35 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 758 bytes |
コンパイル時間 | 254 ms |
コンパイル使用メモリ | 82,732 KB |
実行使用メモリ | 66,848 KB |
最終ジャッジ日時 | 2025-07-29 11:37:38 |
合計ジャッジ時間 | 2,556 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | RE * 1 |
other | AC * 2 RE * 10 |
ソースコード
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))