並查集 7 9 部落 25分

2021-10-17 11:25:07 字數 2213 閱讀 9144

//有不對的地方請多指正
並查集型別的題,基本上結構相似。

這個結構是查詢連通分支(人際關係類)

主要由乙個陣列來儲存每個成員

其中陣列的值初始是其本身

在後期處理的過程中 同乙個圈子裡的人(路徑裡的通路)都指向同乙個人,在檢驗兩個人是否屬於同1個圈子時 只需用find函式來對比是否相同即可驗證 而被指向的這個人也指向自己本身 如果沒有指向自己 就繼續查詢下去 直到找到最終那個人

比如 判斷乙個人是否是乙個大學的

學生指向老師 老師指向院長 院長指向校長 校長指向自身

這樣如果我們有學生a b 一直用find函式查詢到校長 如果相同就是乙個學校的 否則不是

當然 在後期也可以對陣列進行進一步處理 讓所有學生都指向校長。

int pre[

10001

]

之後是乙個初始化用的函式

void

init()

還有兩個主要的結構

find() 和 merge()

find

int

find

(int x)

//或者

intfind

(int x)

merge

void

merge

(int x,

int y)

這個函式就是在後期錄入資料的時候 將同一組資料裡的「人」歸併到同乙個組裡。

這樣原來指向x的和指向fx的數也間接的指向了fy 這樣就聯通了這些間接的關係

7-9 部落 (25分)

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

輸入格式:

輸入在第一行給出乙個正整數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

輸出格式:

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

輸入樣例:

4310

1223

4415

7839

64210

537

輸出樣例:

102y

n

這個是還不太懂的時候參考同學的

#include

#include

using

namespace std;

int father[

10005];

void

init()

}int

find

(int x)

void

merge

(int x,

int y)

intmain()

} set<

int> cnt;

for(

int i=

1;i<=st.

size()

;i++

) cout

<<

" "

cin>>q;

while

(q--

)}

L2 024 部落 25分 並查集

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

L2 024 部落 25 分 並查集

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

L2 024 部落 25分 並查集

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