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;
#define int long long
int n,m,D;
bool betwn(int a,int b, int x){
return ((a<=x&&x<=b)||(a<=x+D&&x+D<=b));
}
void solve(){
// Input:
ios::sync_with_stdio(false); cin.tie(nullptr);
cin>>n>>m>>D;
vector<pair<int,int>> celA(n);
vector<pair<int,int>> celB(m);
for (int i = 0; i < n; i++) {
cin >> celA[i].first >> celA[i].second;
celA[i].first%=D;
celA[i].second%=D;
//if(celA[i].first<=D/2) celA[i].first+=D;
//if(celA[i].second<=D/2) celA[i].second+=D;
}
for (int i = 0; i < m; i++) {
cin >> celB[i].first >> celB[i].second;
celB[i].first%=D;
celB[i].second%=D;
//if(celB[i].first<=D/2) celB[i].first+=D;
//if(celB[i].second<=D/2) celB[i].second+=D;
}
int ans=1e10;
for (int c = 0; c <= D; c++)
{
for (int b = 0; b <= 2*D; b++)
{
for (int d = c; d <= c+D; d++)
{
int a=1e10;
bool br=false;
for (int i = 0; i < n; i++) {
if(!(betwn(-D,b,celA[i].first)&&betwn(c,d,celA[i].second))) { br=true; break; }
if(b>=D+celA[i].first) continue;
a=min(celA[i].first,a);
}
if(br) continue;
for (int i = 0; i < m; i++) {
if(!(betwn(-D,b,celB[i].first)||betwn(c,d,celB[i].second))) { br=true; break; }
if(betwn(c,d,celB[i].second)||b>=D+celB[i].first) continue;
a=min(celB[i].first,a);
}
if(br||a==1e10) continue;
ans=min(ans, ((b-a)+1)*((d-c)+1));
}
}
}
cout << ans << "\n";
}
signed main() {
solve();
return 0;
}
# | 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... |