Submission #529416

#TimeUsernameProblemLanguageResultExecution timeMemory
529416wiwihoSelf Study (JOI22_ho_t2)C++14
0 / 100
198 ms9924 KiB
#include <bits/stdc++.h> #define iter(a) a.begin(), a.end() using namespace std; typedef long long ll; ll iceil(ll a, ll b){ return (a + b - 1) / b; } int n; ll m; vector<ll> a, b; ll tans; bool check(ll mn){ ll cnt = 0; for(int i = 1; i <= n; i++){ ll need = iceil(mn, a[i]); if(need <= m){ cnt += m - need; continue; } ll tmp = mn - m * a[i]; assert(tmp > 0); cnt -= iceil(tmp, b[i]); } if(cnt >= 0) assert(mn <= tans); else assert(mn > tans); return cnt >= 0; } mt19937 rnd(123123); uniform_int_distribution<int> ud(48763, 123456); int main(){ ios_base::sync_with_stdio(false); cin.tie(0); cin >> n >> m; a.resize(n + 1); b.resize(n + 1); for(int i = 1; i <= n; i++) cin >> a[i]; for(int i = 1; i <= n; i++) cin >> b[i]; //for(int i = 1; i <= n; i++) a[i] = ud(rnd); //for(int i = 1; i <= n; i++) b[i] = ud(rnd); for(int i = 1; i <= n; i++) a[i] = max(a[i], b[i]); //for(int i = 1; i <= 10; i++) cerr << check(i) << " "; //cerr << "\n"; tans = *min_element(a.begin() + 1, a.end()); //cout << *min_element(a.begin() + 1, a.end()) << "\n"; //return 0; ll l = 0, r = 1e15; while(l < r){ ll mid = (l + r + 1) / 2; if(check(mid)) l = mid; else r = mid - 1; } cout << l << "\n"; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...