Submission #815237

#TimeUsernameProblemLanguageResultExecution timeMemory
815237blackyukiFountain Parks (IOI21_parks)C++17
100 / 100
745 ms39724 KiB
#include "parks.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<ll,ll> P;
typedef tuple<ll,ll,ll> PP;
typedef vector<ll> vi;
typedef vector<vi> vvi;
typedef vector<P> vp;
typedef vector<vp> vvp;
typedef vector<bool> vb;
#define rep(i,n) for(ll i=0;i<(ll)(n);i++)
#define REP(i,k,n) for(ll i=(ll)(k);i<(ll)(n);i++)
#define all(a) a.begin(),a.end()
#define fi first
#define se second
#define pb emplace_back
#define lb(v,k) (lower_bound(all(v),k)-v.begin())
template<class T> bool chmin(T&a,T b){if(a>b){a=b;return true;}return false;}
template<class T> bool chmax(T&a,T b){if(a<b){a=b;return true;}return false;}
template<class T> void out(T a){cout<<a<<'\n';}
template<class T> void outv(T v){rep(i,v.size()){if(i)cout<<' ';cout<<v[i];}cout<<'\n';}
const ll inf=1001001001001001001;
struct UF{
	ll n;
	vi par,sz;
	UF(ll n_):n(n_),par(n,-1),sz(n,1){}
	void merge(ll a,ll b){
		a=root(a);b=root(b);
		if(a==b)return;
		if(sz[a]>sz[b])swap(a,b);
		par[a]=b;
		sz[b]+=sz[a];
	}
	ll root(ll i){
		if(par[i]==-1)return i;
		par[i]=root(par[i]);
		return par[i];
	}
	bool same(ll a,ll b){
		return root(a)==root(b);
	}
    ll getsz(ll i){
        return sz[root(i)];
    }
};
int construct_roads(std::vector<int> x, std::vector<int> y) {
    ll n=x.size();
    UF uf(n);
    vector<PP> v(n);
    rep(i,n)v[i]=PP(x[i],y[i],i);
    sort(all(v));
    vi dx={2,0},dy={0,2};
    set<P> S;
    vector<int> U, V, A, B;
    rep(k,4)rep(i,n)rep(j,2){
        P a(x[i],y[i]),b(x[i]+dx[j],y[i]+dy[j]);
        ll l=lb(v,PP(b.fi,b.se,-1));
        if(l==n)continue;
        l=get<2>(v[l]);
        if(P(x[l],y[l])!=b)continue;
        P c((a.fi+b.fi)/2,(a.se+b.se)/2);
        if(a.fi==b.fi){
            if((a.fi+a.se)%4!=k)continue;
            if((a.fi+a.se)%4==0)c.fi--;
            else c.fi++;
        }
        else{
            if((a.fi+a.se)%4!=k)continue;
            if((a.fi+a.se)%4==0)c.se++;
            else c.se--;
        }
            uf.merge(i,l);
        if(S.insert(c).se){
            U.pb(i);
            V.pb(l);
            A.pb(c.fi);
            B.pb(c.se);
        }
    }
    if(uf.getsz(0)<n)return 0;
    build(U,V,A,B);
    return 1;
}
#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...