結果
| 問題 | 
                            No.3022 一元一次式 mod 1000000000
                             | 
                    
| コンテスト | |
| ユーザー | 
                             kidodesu
                         | 
                    
| 提出日時 | 2025-02-14 21:52:09 | 
| 言語 | PyPy3  (7.3.15)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 362 ms / 2,000 ms | 
| コード長 | 357 bytes | 
| コンパイル時間 | 470 ms | 
| コンパイル使用メモリ | 82,176 KB | 
| 実行使用メモリ | 77,312 KB | 
| 最終ジャッジ日時 | 2025-02-17 12:56:31 | 
| 合計ジャッジ時間 | 2,817 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 21 | 
ソースコード
N = 10**9
from math import gcd
def make():
    n, m = map(int, input().split())
    n %= N
    m %= N
    r = N - m
    g = gcd(n, N)
    if r % g != 0:
        print(-1)
        return
    r //= g
    n //= g
    M = N // g
    ans = r * pow(n, -1, M) % M
    if ans == 0:
        ans = M
    print(ans)
    return
for _ in range(int(input())):
    make()
            
            
            
        
            
kidodesu