天梯賽 L2 024 部落 25分

2021-10-05 12:42:43 字數 1303 閱讀 7676

在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。

輸入格式:

輸入在第一行給出乙個正整數n(≤10

​4​​ ),是已知小圈子的個數。隨後n行,每行按下列格式給出乙個小圈子裡的人:

k p[1] p[2] ⋯ p[k]

其中k是小圈子裡的人數,p[i](i=1,⋯,k)是小圈子裡每個人的編號。這裡所有人的編號從1開始連續編號,最大編號不會超過10

​4​​ 。

之後一行給出乙個非負整數q(≤10

​4​​ ),是查詢次數。隨後q行,每行給出一對被查詢的人的編號。

輸出格式:

首先在一行中輸出這個社群的總人數、以及互不相交的部落的個數。隨後對每一次查詢,如果他們屬於同乙個部落,則在一行中輸出y,否則輸出n。

輸入樣例:

43 10 1 2

2 3 4

4 1 5 7 8

3 9 6 4

210 5

3 7輸出樣例:

10 2yn

並集問題,設定note陣列,通過note陣列找到最後乙個加入該部落的人,通過最後乙個加入部落的人來標記是否是同乙個部落。並且每次加入新成員的時候,更新的是上一次最後加入部落的note值。

note[i] = i; 說明該編號為i的人是最後乙個加入部落的

note[i]!=i; 則說明編號為note[i]的人在i後乙個加入部落

find函式返回的是最後加入的人

int find(int n)

當部落的人逐漸增加時,find函式會超時,下面做出改進

int find(int n)

//把屬於這個部落的每個人note[i]的值全部設定為最後乙個進入部落的人的編號,在以後的尋找中要麼需要更新,要麼可以直接提供結果

return n;

}

#include#includeusing namespace std;

const int maxx = 1e4+5;

int note[maxx];

int my_find(int n)

return n;

}void my_merge(int n1,int n2)

}int main()

}for(int i = 1;i<=count_p.size();i++)

return 0;

}

天梯賽 L2 024部落(並查集)

在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。輸入格式 輸入在第一行給出乙個正整數n 10 4 是已知小圈子的個數。隨後n行,每行按下列...

天梯賽L2 024 部落 並查集

在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。輸入格式 輸入在第一行給出乙個正整數n 10 4 是已知小圈子的個數。隨後n行,每行按下列...

L2 024 部落 25分 並查集

題目描述 在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。輸入格式 輸入在第一行給出乙個正整數n 10 4 是已知小圈子的個數。隨後n行,...