結果
問題 | No.186 中華風 (Easy) |
ユーザー |
![]() |
提出日時 | 2023-06-04 22:33:39 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 39 ms / 2,000 ms |
コード長 | 617 bytes |
コンパイル時間 | 316 ms |
コンパイル使用メモリ | 82,260 KB |
実行使用メモリ | 54,108 KB |
最終ジャッジ日時 | 2024-12-29 04:00:22 |
合計ジャッジ時間 | 2,015 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 23 |
ソースコード
def extgcd(a, b): """returns gcd(a, b), s, r s.t. a * s + b * r == gcd(a, b)""" s, bs = 0, 1 r, br = b, a while r: q = br // r br, r = r, br - q * r bs, s = s, bs - q * s return br, bs, (br-bs*a)//b if b else 0 def crt(V): """最小のxと最小公倍数dを返す""" x = 0; d = 1 for X, Y in V: g, a, b = extgcd(d, Y) x, d = (Y*b*x + d*a*X) // g, d*(Y // g) x %= d return x, d a = [list(map(int, input().split())) for _ in range(3)] x,d = crt(a) for X,Y in a: if x%Y!=X: print(-1) exit() print(x if x else x+d)