Submission #592892

#TimeUsernameProblemLanguageResultExecution timeMemory
592892fuad27Robots (IOI13_robots)C++17
90 / 100
1518 ms16828 KiB
#include "robots.h" #include<bits/stdc++.h> using namespace std; #pragma GCC optimize("O3,unroll-loops") #pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt") int putaway(int A, int B, int T, int X[], int Y[], int W[], int S[]) { if(B == 0) { sort(X, X+A); int lo = 0, hi = 2*T; int res=-1; while(lo <= hi) { bool check=1; int mid = (lo+hi)/2; vector<int> v(A); for(int i = 0;i<T;i++) { int it = upper_bound(X, X+A, W[i])-X; if(it == A) { check=0; break; } v[it]++; } if(check) { for(int i = 0;i<A-1;i++) { if(v[i] > mid) { v[i+1]+=v[i]-mid; v[i]=mid; } } } if(v.back() > mid or !check) { lo = mid+1; } else { res=mid; hi=mid-1; } } return res; } else if(A == 0) { sort(Y, Y+B); int lo = 0, hi = 2*T; int res=-1; while(lo <= hi) { bool check=1; int mid = (lo+hi)/2; vector<int> v(B); for(int i = 0;i<T;i++) { int it = upper_bound(Y, Y+B, S[i])-Y; if(it == B) { check=0; break; } v[it]++; } if(check) { for(int i = 0;i<B-1;i++) { if(v[i] > mid) { v[i+1]+=v[i]-mid; v[i]=mid; } } } if(v.back() > mid or !check) { lo = mid+1; } else { res=mid; hi=mid-1; } } return res; } sort(X, X+A); sort(Y, Y+B); int lo = 0, hi = 2*T; while(hi-lo > 1) { // (lo,hi] int mid = (lo+hi)/2, check=1; priority_queue<int> pq; vector<int> vv; vector<int> v[A]; for(int i = 0;i<T;i++) { int it = upper_bound(X, X+A, W[i])-X; if(it == A)vv.push_back(S[i]); else v[it].push_back(S[i]); } for(int i = 0;i<A;i++) { int cnt = 0; for(int j:v[i])pq.push(j); while(cnt < mid and pq.size()) { pq.pop(); cnt++; } } for(int i:vv)pq.push(i); vector<int> v2(B); while(pq.size()) { int t = pq.top(); pq.pop(); int idx=upper_bound(Y, Y+B, t)-Y; if(idx==B){ check=0; break; } v2[idx]++; } if(!check) { lo = mid+1; continue; } for(int i = 0;i<B-1;i++) { if(v2[i] > mid) { v2[i+1]+=v2[i]-mid; v2[i]=mid; } } if(v2.back() > mid) { lo = mid; } else { hi = mid; } } if(hi == 2*T)return -1; return hi; }
#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...