255042026-02-20 12:41:10KevinSportos nyaraláscpp17Időlimit túllépés 1/401.1s1780 KiB
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
using pll=pair<ll, ll>;

vector<ll> bicikli, kajak;

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

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

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);
    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--;
        if (a>b) swap(a, b);
        bicikli[b]=a;
    }
    vector<ll> out(n);
    for (ll i=0; i<k; i++){
        ll a, b; cin >> a >> b; a--; b--;
        if (a>b) swap(a, b);
        kajak[b]=a;
        if (rootB(a)==rootB(b) && rootK(a)==rootK(b)){
            //out[a]++; out[b]++;
        }
    }
    for (ll i=0; i<n-1; i++){
        for (ll j=i+1; j<n; j++){
            if (rootB(i)==rootB(j) && rootK(i)==rootK(j)){
                out[i]++; out[j]++;
            }
        }
    }
    for (auto& z:out) cout << z << ' ';
}

RészfeladatÖsszpontTesztVerdiktIdőMemória
base1/40
1Elfogadva0/01ms316 KiB
2Időlimit túllépés0/01.082s1592 KiB
3Elfogadva1/11ms512 KiB
4Hibás válasz0/11ms316 KiB
5Hibás válasz0/11ms336 KiB
6Hibás válasz0/11ms316 KiB
7Hibás válasz0/11ms316 KiB
8Hibás válasz0/11ms316 KiB
9Hibás válasz0/11ms316 KiB
10Hibás válasz0/12ms540 KiB
11Hibás válasz0/23ms316 KiB
12Hibás válasz0/22ms316 KiB
13Hibás válasz0/28ms444 KiB
14Hibás válasz0/27ms440 KiB
15Időlimit túllépés0/21.1s1080 KiB
16Időlimit túllépés0/21.098s1324 KiB
17Időlimit túllépés0/31.1s1588 KiB
18Időlimit túllépés0/31.077s1780 KiB
19Időlimit túllépés0/21.067s1076 KiB
20Időlimit túllépés0/21.1s1352 KiB
21Időlimit túllépés0/21.1s1588 KiB
22Időlimit túllépés0/21.085s1476 KiB
23Időlimit túllépés0/31.085s1588 KiB
24Időlimit túllépés0/31.082s1588 KiB