結果
| 問題 |
No.1544 [Cherry 2nd Tune C] Synchroscope
|
| コンテスト | |
| ユーザー |
tktk_snsn
|
| 提出日時 | 2021-06-11 21:57:35 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 355 ms / 2,000 ms |
| コード長 | 776 bytes |
| コンパイル時間 | 436 ms |
| コンパイル使用メモリ | 82,476 KB |
| 実行使用メモリ | 65,240 KB |
| 最終ジャッジ日時 | 2024-12-14 23:28:50 |
| 合計ジャッジ時間 | 6,280 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 48 |
ソースコード
def extgcd(a, b):
"""
拡張Euclidの互除法
INPUT:
a, b
OUTPUT:
d: gcd(a, b)
(x, y): ax + by = d の解
"""
if b == 0:
return a, (1, 0)
d, (y, x) = extgcd(b, a % b)
y -= a // b * x
return d, (x, y)
N, M = map(int, input().split())
A = list(map(int, input().split()))
B = list(map(int, input().split()))
g, (x, y) = extgcd(N, -M)
lcm = N * (M // -g)
ans = 10**18
for i, a in enumerate(A, 1):
for j, b in enumerate(B, 1):
if a != b:
continue
if (j - i) % g != 0:
continue
d = (j - i) // g
tmp = d * N * x + i
tmp %= lcm
if tmp == 0:
tmp += lcm
ans = min(ans, tmp)
if ans >= 10**18:
ans = -1
print(ans)
tktk_snsn