結果
| 問題 |
No.1544 [Cherry 2nd Tune C] Synchroscope
|
| コンテスト | |
| ユーザー |
tktk_snsn
|
| 提出日時 | 2021-06-11 21:53:19 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 732 bytes |
| コンパイル時間 | 103 ms |
| コンパイル使用メモリ | 12,416 KB |
| 実行使用メモリ | 22,656 KB |
| 最終ジャッジ日時 | 2024-12-14 23:19:23 |
| 合計ジャッジ時間 | 88,311 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 22 WA * 1 TLE * 25 |
ソースコード
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
ans = min(ans, tmp)
if ans >= 10**18:
ans = -1
print(ans)
tktk_snsn