This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "robots.h"
#include <bits/stdc++.h>
using namespace std;
int a,b,t;
vector<pair<int,int>> sortedbyx;
vector<int> xv;
vector<int> yv;
vector<int> wv;
vector<int> sv;
bool BSTA(int time) {
//cout << "BSTA" << " " << time << endl;
priority_queue<int> leftvalues;
int pointer=0;
//start by placing the vertical dividers
for (int i=0; i<a; i++) {
int val=wv[i];
int ct=0;
//put into the set as {y,x}
while (pointer<t && sortedbyx[pointer].first < val) {
//cout <<pointer <<" " << "INSERTING " << -sortedbyx[pointer].second << endl;
leftvalues.push(sortedbyx[pointer].second);
pointer++;
}
while (ct<time && leftvalues.size()) {
leftvalues.pop();
ct++;
}
}
while (pointer<t) {
leftvalues.push(sortedbyx[pointer].second);
pointer++;
}
int work=1;
vector<int> normalvalues; //y values
while (leftvalues.size()) {
normalvalues.push_back(leftvalues.top());
leftvalues.pop();
}
sort(normalvalues.begin(), normalvalues.end());
/*for (auto i:normalvalues) {
cout << i << " ";
}
cout << endl;*/
int cur=0;
int lastr=0;
for (int i=0; i<b; i++) {
int r=lower_bound(normalvalues.begin(), normalvalues.end(), sv[i])-normalvalues.begin();
r=normalvalues.size()-r;
//cout <<"megabloat " << i <<" " << sv[i] <<" " << r << endl;
if (i==b-1 && r>0) {
return 0;
}
else if (i!=b-1 && (r/((b-i-1))>time || (r/((b-i-1))==time && r%(b-i-1)!=0))) {
//cout <<"BSTA" <<" " << time <<" " << 0 << endl;
return 0;
}
}
if (normalvalues.size() > b*time) {
return 0;
}
//cout <<"BSTA" <<" " << time <<" " << 1;
return 1;
}
int putaway(int A, int B, int T, int X[], int Y[], int W[], int S[]) {
a=A;
b=B;
t=T;
xv=vector<int>(T,-1);
yv=vector<int>(T,-1);
wv=vector<int>(A,-1);
sv=vector<int>(B,-1);
for (int i=0; i<T; i++) {
xv[i] = W[i];
yv[i] = S[i];
sortedbyx.push_back({W[i], S[i]});
}
sort(sortedbyx.begin(), sortedbyx.end());
for (auto i:sortedbyx) {
//cout << i.first <<" " << i.second << endl;
}
int mw=0;
int ms=0;
for (int i=0; i<A; i++) {
wv[i] = X[i];
mw=max(mw,X[i]);
}
for (int i=0; i<B; i++) {
sv[i] = Y[i];
ms=max(ms,Y[i]);
}
sort(wv.begin(), wv.end());
sort(sv.begin(), sv.end());
for (int i=0; i<T; i++) {
//cout << i <<" " << mw << " " << ms <<" " << W[i] <<" " << S[i] << endl;
if (W[i] >= mw && S[i] >= ms) {
return -1;
}
}
int l=1;
int r=T*2;
while (l<r) {
int m=(l+r)/2;
int bst=BSTA(m);
//cout << l <<" " << r << " " << m <<" " << bst << endl;
if (bst) {
l=l;
r=m;
}
else {
l=m+1;
r=r;
}
}
if (l>0 && BSTA(l-1)) {
l--;
}
if (!BSTA(l)) {
l++;
}
if (l>T) {
return -1;
}
return l;
}
Compilation message (stderr)
robots.cpp: In function 'bool BSTA(int)':
robots.cpp:64:29: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
64 | if (normalvalues.size() > b*time) {
| ~~~~~~~~~~~~~~~~~~~~^~~~~~~~
robots.cpp:38:9: warning: unused variable 'work' [-Wunused-variable]
38 | int work=1;
| ^~~~
robots.cpp:50:9: warning: unused variable 'cur' [-Wunused-variable]
50 | int cur=0;
| ^~~
robots.cpp:51:9: warning: unused variable 'lastr' [-Wunused-variable]
51 | int lastr=0;
| ^~~~~
robots.cpp: In function 'int putaway(int, int, int, int*, int*, int*, int*)':
robots.cpp:89:15: warning: variable 'i' set but not used [-Wunused-but-set-variable]
89 | for (auto i:sortedbyx) {
| ^
# | 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... |