結果
問題 |
No.3127 Multiple of Twin Prime
|
ユーザー |
![]() |
提出日時 | 2025-04-25 21:39:22 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,075 ms / 2,500 ms |
コード長 | 1,108 bytes |
コンパイル時間 | 369 ms |
コンパイル使用メモリ | 82,452 KB |
実行使用メモリ | 256,856 KB |
最終ジャッジ日時 | 2025-04-25 21:39:57 |
合計ジャッジ時間 | 16,299 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 12 |
ソースコード
def Sieve(n): #n以下の素数全列挙(O(nloglogn)) retは素数が入ってる。divlisはその数字の素因数が一つ入ってる ret = [] divlis = [-1] * (n+1) #何で割ったかのリスト(初期値は-1) flag = [True] * (n+1) flag[0] = False flag[1] = False ind = 2 while ind <= n: if flag[ind]: ret.append(ind) ind2 = ind ** 2 while ind2 <= n: flag[ind2] = False divlis[ind2] = ind ind2 += ind ind += 1 return ret,divlis plis,_ = Sieve(10**7+2000) qlis = [] for i in range(len(plis)-1): if plis[i+1] == plis[i] + 2: qlis.append(plis[i]) # print (len(qlis)) TT = int(input()) ANS = [] for loop in range(TT): N = int(input()) if qlis[0] * (qlis[0]+2) > N: ANS.append(-1) continue L = 0 R = len(qlis) while R-L != 1: M = (L+R)//2 if qlis[M] * (qlis[M]+2) <= N: L = M else: R = M ANS.append( qlis[L] * (qlis[L]+2) ) print (*ANS,sep="\n")