255242026-02-20 14:14:26KevinSportos nyaraláscpp17Időlimit túllépés 16/401.1s12844 KiB
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
using pll=pair<ll, ll>;

vector<ll> bicikli, kajak;
vector<set<ll>> setB, setK;

ll rootB(ll x){
    if (bicikli[x]==x) return x;
    bicikli[x]=rootB(bicikli[x]);
    return bicikli[x];
}

ll rootK(ll x){
    if (kajak[x]==x) return x;
    kajak[x]=rootK(kajak[x]);
    return kajak[x];
}

void unioB(ll a, ll b){
    a=rootB(a); b=rootB(b);
    if (a>b) swap(a, b);
    bicikli[b]=a;
}

void unioK(ll a, ll b){
    a=rootK(a); b=rootK(b);
    if (a>b) swap(a, b);
    kajak[b]=a;
}

ll solve(ll x){
    set<ll> s=setB[rootB(x)];
    s.insert(setK[rootK(x)].begin(), setK[rootK(x)].end());
    return setB[rootB(x)].size()+setK[rootK(x)].size()-s.size()-1;
}

int main() {
    ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
    ll n, m, k; cin >> n >> m >> k;
    bicikli.resize(n); kajak.resize(n);
    setB.resize(n); setK.resize(n);
    for (ll i=0; i<n; i++){
        bicikli[i]=i; kajak[i]=i;
    }
    for (ll i=0; i<m; i++){
        ll a, b; cin >> a >> b; a--; b--;
        unioB(a, b);
    }
    for (ll i=0; i<k; i++){
        ll a, b; cin >> a >> b; a--; b--;
        unioK(a, b);
    }
    for (ll i=0; i<n; i++){
        setB[rootB(i)].insert(i);
        setK[rootK(i)].insert(i);
    }
    /*
    for (ll i=0; i<n; i++) cerr << rootB(i) << ' ';
    cerr << '\n';
    for (ll i=0; i<n; i++) cerr << rootK(i) << ' ';
    cerr << '\n';
    for (ll i=0; i<n; i++) cerr << setB[i].size() << ' ';
    cerr << '\n';
    for (ll i=0; i<n; i++) cerr << setK[i].size() << ' ';
    cerr << '\n';
    */
    for (ll i=0; i<n; i++){
        cout << solve(i) << ' ';
    }
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base16/40
1Elfogadva0/01ms316 KiB
2Időlimit túllépés0/01.092s12844 KiB
3Elfogadva1/11ms316 KiB
4Elfogadva1/11ms316 KiB
5Elfogadva1/11ms316 KiB
6Elfogadva1/11ms316 KiB
7Elfogadva1/11ms316 KiB
8Elfogadva1/11ms316 KiB
9Elfogadva1/11ms316 KiB
10Elfogadva1/12ms316 KiB
11Elfogadva2/2109ms564 KiB
12Elfogadva2/213ms316 KiB
13Elfogadva2/276ms748 KiB
14Elfogadva2/281ms564 KiB
15Időlimit túllépés0/21.078s7412 KiB
16Időlimit túllépés0/21.1s9780 KiB
17Időlimit túllépés0/31.1s12232 KiB
18Időlimit túllépés0/31.082s12344 KiB
19Időlimit túllépés0/21.082s7732 KiB
20Időlimit túllépés0/21.09s10804 KiB
21Időlimit túllépés0/21.093s11572 KiB
22Időlimit túllépés0/21.082s12084 KiB
23Időlimit túllépés0/31.087s12568 KiB
24Időlimit túllépés0/31.088s12576 KiB