#include <bits/stdc++.h>
using namespace std;
using ll = long long;
ll cdiv(ll a, ll b) {
return (a + b - 1) / b;
}
void solve() {
int n, m;
cin >> n >> m;
vector<ll> a(n), b(n);
for (auto &i: a) cin >> i;
for (auto &i: b) cin >> i;
for (int i = 0; i < n; i++) a[i] = max(a[i], b[i]);
// solve
auto check = [&](ll x) {
ll days = 0;
for (int i = 0; i < n; i++) {
ll adays = min((ll)m, cdiv(x, a[i]));
days += adays;
ll rem = x - adays * a[i];
if (rem > 0) days += cdiv(rem, b[i]);
}
return (days <= m * n);
};
ll l = 0, r = 1LL << 60;
while (l < r) {
ll mid = (l + r + 1) / 2;
if (check(mid)) l = mid;
else r = mid - 1;
}
// ans
cout << l << '\n';
}
signed main() {
cin.tie(0)->sync_with_stdio(0);
solve();
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |