이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "robots.h"
#include <bits/stdc++.h>
using namespace std;
#define all(x) begin((x)), end((x))
#define g(x) "[" << #x << ": " << x << "] "
int putaway(int n, int m, int toys, int a[], int b[], int w[], int sz[]) {
// n of type a - sz doesnt matter
// m of type b - weight doesnt matter
// cerr<<g(toys);
sort(a, a+n);
sort(b, b+m);
vector<int> idx(toys);
for(int i=0;i<toys;i++){
idx[i] = i;
}
if(n==m && n ==0){
return -1;
}
int lo = 0;
int hi = toys+1;
sort(all(idx), [&](int one, int two){
return w[one] < w[two];
});
auto f = [&](int how){
priority_queue<pair<int, int>> pq;
// start with a since I care about weight but not abotu size
int cur = 0;
for(int i=0;i<n;i++){
while(cur<toys&&w[idx[cur]] < a[i]){
pq.push({sz[idx[cur]], w[idx[cur]]});
cur++;
}
int cnt = 0;
while(cnt < how && !pq.empty()){
pq.pop();
cnt++;
}
}
vector<int> rems;
while(!pq.empty()){
rems.push_back(pq.top().first);
pq.pop();
}
for(int i=cur;i<toys;i++){
rems.push_back(sz[idx[cur]]);
}
sort(all(rems));
// cerr<<g(how) <<'\n';
// for(int i=0;i<rems.size();i++){
// cerr<<g(i) << g(rems[i]);
// }
// cerr<<'\n';
for(int i=m-1;i>=0;i--){
int cnt = 0;
while(cnt<how&&!rems.empty()&&b[i] > rems.back()){
cnt++;
rems.pop_back();
}
}
return rems.empty();
};
if(f(toys) == 0){
return -1;
}
while(hi != lo){
int mid = (hi+lo)/2;
if(f(mid)){
hi = mid;
} else{
lo = mid+1;
}
}
return hi;
}
# | 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... |