# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
226781 | MKopchev | Hamburg Steak (JOI20_hamburg) | C++14 | 167 ms | 6636 KiB |
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<bits/stdc++.h>
using namespace std;
const int nmax=2e5+42;
struct rect
{
int x1,y1,x2,y2;
};
int n,k;
rect inp[nmax];
rect outp[nmax];
mt19937 rng(42);
int main()
{
scanf("%i%i",&n,&k);
for(int i=1;i<=n;i++)
{
scanf("%i%i%i%i",&inp[i].x1,&inp[i].y1,&inp[i].x2,&inp[i].y2);
}
vector<int> correct={},wrong={};
for(int i=1;i<=n;i++)wrong.push_back(i);
while(1)
{
vector<int> order={};
shuffle(wrong.begin(),wrong.end(),rng);
for(auto p:wrong)order.push_back(p);
for(auto p:correct)order.push_back(p);
wrong={};
correct={};
//for(auto w:order)cout<<w<<" ";cout<<endl;
for(int i=1;i<=k;i++)
{
outp[i].x1=1;
outp[i].y1=1;
outp[i].x2=1e9;
outp[i].y2=1e9;
}
bool ok=1;
for(auto i:order)
{
if(ok==0){wrong.push_back(i);continue;}
bool choose=0;
for(int j=1;j<=k;j++)
{
int x1=max(inp[i].x1,outp[j].x1);
int y1=max(inp[i].y1,outp[j].y1);
int x2=min(inp[i].x2,outp[j].x2);
int y2=min(inp[i].y2,outp[j].y2);
if(x1<=x2&&y1<=y2)
{
choose=1;
outp[j].x1=x1;
outp[j].y1=y1;
outp[j].x2=x2;
outp[j].y2=y2;
correct.push_back(i);
break;
}
}
if(choose==0){ok=0;}
}
if(ok)
{
for(int j=1;j<=k;j++)
printf("%i %i\n",outp[j].x1,outp[j].y1);
return 0;
}
}
return 0;
}
Compilation message (stderr)
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |