結果
問題 | No.2767 Add to Divide |
ユーザー |
👑 |
提出日時 | 2024-05-08 14:35:25 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 83 ms / 2,000 ms |
コード長 | 456 bytes |
コンパイル時間 | 510 ms |
コンパイル使用メモリ | 82,304 KB |
実行使用メモリ | 73,272 KB |
最終ジャッジ日時 | 2024-12-14 19:25:39 |
合計ジャッジ時間 | 2,216 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
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: if A<2:t=1 D=[1] for p in P: c=0 while e%p<1:e//=p;c+=1; r=len(D) for i in R(c): for m in[n*p for n in D[-r:]]: D+=[m] if A<=m<t:t=m r=len(D) if e>1: for m in[n*e for n in D[-r:]]: D+=[m] if A<=m<t:t=m print([0,max(t-A,-1)][e>0])