結果
問題 |
No.2767 Add to Divide
|
ユーザー |
👑 |
提出日時 | 2024-05-08 14:26:20 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 79 ms / 2,000 ms |
コード長 | 419 bytes |
コンパイル時間 | 153 ms |
コンパイル使用メモリ | 82,384 KB |
実行使用メモリ | 69,504 KB |
最終ジャッジ日時 | 2024-12-14 19:20:42 |
合計ジャッジ時間 | 2,035 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 16 |
ソースコード
I,R,O=input,range,print L=9**5 P=[] C=[0]*L for i in R(2,L): if C[i]<1: P+=[i] j=i*i while j<L:C[j],j=1,j+i for t in R(int(I())): A,B=map(int,I().split()) t=e=B-A if e: D=[1] for p in P: c=0 while e%p<1:e//=p;c+=1; r=len(D) for i in R(c):D+=[n*p for n in D[-r:]] r=len(D) if e>1:D+=[n*e for n in D[-r:]];r*=2 D.sort() r-=1 while r and D[r-1]>=A:r-=1 print(max(D[r]-A,-1)if e else 0)