61572023-11-04 00:06:29horvathabelMobilNet (50 pont)cpp17Futási hiba 44/50272ms62900 KiB
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
ll cnt=0;
vector<ll> p;
vector<ll> siz;
ll maxw=0;
ll ans=0;
struct node{
    ll a;
    ll b;
    ll w;

};

ll holvan(ll a){
    if (p[a]==-1) return a;
    return p[a]=holvan(p[a]);
}
void unio(ll a,ll b, ll w){
    a=holvan(a);
    b=holvan(b);
    if (a!=b){
        cnt++;
        if (w>maxw){
            maxw=w;
            ans=0;
        }
        if (w==maxw) ans++;
        if (siz[a]>siz[b]){
            siz[a]++;
            p[b]=a;
            return;
        }
        siz[b]++;
        p[a]=b;
    }
}
vector<node> g;
bool r(node a, node b){
return (a.w<b.w) ;
}

int main()
{
    int n;
    cin>>n;
    p.resize(n+1,-1);
    siz.resize(n+1,1);
    vector<pair<ll, ll>> z;
    map<ll,vector<pair<ll,ll>>> xk;
    map<ll,vector<pair<ll,ll>>> yk;

    for (int i=0; i<n;i++){
        ll x,y;
        cin>>x>>y;
        z.push_back({x,y});
        yk[y].push_back({x,i});
        xk[x].push_back({y,i});
        for (pair<int,int> a:xk[x]){
            if (i!=a.second) g.push_back({i,a.second,abs(y-a.first)});
        }
        for (pair<int,int> a:yk[y]){
            if (i!=a.second)  g.push_back({i,a.second,abs(x-a.first)});
        }

    }
    sort(g.begin(),g.end(), r);
    ll i=0;
    while (cnt<n-1 && i<g.size()){
        unio(g[i].a,g[i].b,g[i].w);
        i++;
    }
    cout<<maxw<<"\n";
    cout<<ans;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base44/50
1Elfogadva0/03ms1876 KiB
2Elfogadva0/014ms4572 KiB
3Elfogadva2/23ms2224 KiB
4Elfogadva2/23ms2376 KiB
5Elfogadva2/23ms2316 KiB
6Elfogadva2/23ms2656 KiB
7Elfogadva2/24ms2960 KiB
8Elfogadva2/24ms3372 KiB
9Elfogadva2/27ms4140 KiB
10Elfogadva2/28ms4412 KiB
11Elfogadva2/212ms5080 KiB
12Elfogadva2/219ms6716 KiB
13Elfogadva3/332ms9576 KiB
14Elfogadva3/359ms20436 KiB
15Elfogadva3/3156ms34380 KiB
16Elfogadva3/393ms22572 KiB
17Elfogadva3/3111ms26436 KiB
18Futási hiba0/386ms62900 KiB
19Elfogadva3/3272ms61352 KiB
20Futási hiba0/386ms62656 KiB
21Elfogadva3/3193ms39248 KiB
22Elfogadva3/3189ms39064 KiB