結果
| 問題 | No.3461 Min GCD |
| コンテスト | |
| ユーザー |
kidodesu
|
| 提出日時 | 2026-02-28 14:06:53 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 1,589 ms / 2,000 ms |
| コード長 | 984 bytes |
| 記録 | |
| コンパイル時間 | 365 ms |
| コンパイル使用メモリ | 78,076 KB |
| 実行使用メモリ | 347,024 KB |
| 最終ジャッジ日時 | 2026-02-28 14:07:09 |
| 合計ジャッジ時間 | 10,713 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge7 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 21 |
ソースコード
n, k = list(map(int, input().split()))
A = list(map(int, input().split()))
B = list(map(int, input().split()))
C = [[] for _ in range(n)]
D = [[] for _ in range(n)]
P = [[] for _ in range(10**5+1)]
for i in range(2, 10**5+1):
for j in range(i, 10**5+1, i):
P[j].append(i)
for i in range(n):
a, b = A[i], B[i]
if a == 1:
print(1)
exit()
S = [(-1, 0)]
for p in P[a]:
if not b % p:
cost = 0
else:
cost = p - b % p
while S and S[-1][0] >= cost:
S.pop()
S.append((cost, p))
for cost, p in S[1:]:
C[i].append(cost)
D[i].append(p)
from bisect import bisect_left as bs
l = 1
r = 10 ** 5 + 2
while r - l > 1:
m = (l + r) >> 1
t = 0
for i in range(n):
if D[i][-1] < m:
r = m
break
else:
t += C[i][bs(D[i], m)]
else:
if t <= k:
l = m
else:
r = m
print(l)
kidodesu