Submission #899552

#TimeUsernameProblemLanguageResultExecution timeMemory
899552LudisseyGarden (JOI23_garden)C++14
0 / 100
3028 ms12376 KiB
#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=b;
                bool br=false;
                for (int i = 0; i < n; i++) {
                    if(!(betwn(0,b,celA[i].first)&&betwn(c,d,celA[i].second))) { br=true; break; }
                    if(b<D+celA[i].first) a=min(celA[i].first,a);
                    else a=min(celA[i].first+D,a);
                }
                if(br) continue;
                for (int i = 0; i < m; i++) {
                    if(!(betwn(0,b,celB[i].first)||betwn(c,d,celB[i].second))) { br=true; break; }
                    if(!betwn(c,d,celB[i].first)) a=min(celB[i].first,a);
                }
                if(br) continue;
                ans=min(ans, ((b-a)+1)*((d-c)+1));
            }
        }
    }
    cout << ans << "\n";
}

signed main() {
    solve();
    return 0;
}
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...