日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

POJ 1611 The Suspects (并查集)

發布時間:2024/4/14 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 POJ 1611 The Suspects (并查集) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

 文章作者:ktyanny?文章來源:ktyanny?轉載請注明,謝謝合作。?

ktyanny:a的第一道并查集。

題目描述:

有很多組學生,在同一個組的學生經常會接觸,也會有新的同學的加入。但是SARS是很容易傳染的,只要在改組有一位同學感染SARS,那么該組的所有同學都被認為得了SARS。現在的任務是計算出有多少位學生感染SARS了。假定編號為0的同學是得了SARS的。

解題思路---->顯然并查集了。并查集的詳細解釋在可以點擊?并查集(不相交集合)進行學習。采用num[]存儲該集合中元素個數,并在集合合并時更新num[]即可。然后找出0所在的集合的根節點x,因此,num[x]就是answer了。

?

ac代碼: 16MS C++

?

#include?<stdio.h>//by ktyanny
#include?<iostream>
using?namespace?std;

const?int?MAXN?=?30001;?/*結點數目上線*/
int?pa[MAXN];????/*p[x]表示x的父節點*/
int?rank[MAXN];????/*rank[x]是x的高度的一個上界*/
int?num[MAXN];/*num[]存儲該集合中元素個數,并在集合合并時更新num[]即可*/

void?make_set(int?x)
{/*創建一個單元集*/
????pa[x]?=?x;
????rank[x]?=?0;
????num[x]?=?1;
}

int?find_set(int?x)
{/*帶路徑壓縮的查找*/
????
/*保存待查找的數*/
????
int?r?=?x,?temp;
????
/*找到根節點*/
????
while(pa[r]?!=?r)?r?=?pa[r];
????
while(x?!=?r)
????{
????????temp?=?pa[x];
????????pa[x]?=?r;
????????x?=?temp;
????}
????
return?x;
????
//if(x?!=?pa[x]) //注釋掉的其實也是可以的,不過不想用遞歸來做啦
????
//????pa[x]?=?find_set(pa[x]);
????
//return?pa[x];
}

/*按秩合并x,y所在的集合*/
void?union_set(int?x,?int?y)
{
????x?=?find_set(x);
????y?=?find_set(y);
????
if(x?==?y)return?;
????
if(rank[x]?>?rank[y])/*讓rank比較高的作為父結點*/
????{
????????pa[y]?=?x;
????????num[x]?+=?num[y];
????}
????
else?
????{
????????pa[x]?=?y;
????????
if(rank[x]?==?rank[y])
????????????rank[y]++;
????????num[y]?+=?num[x];
????}
}

//answer?to?1611?
int?main()
{
????
int?n,?m,?x,?y,?i,?t,?j;
????
while(scanf("%d%d",?&n,?&m))
????{
????????
if(m==n?&&?n?==?0)?break;
????????
if(m?==?0)
????????{
????????????cout?<<?"1\n";?continue;
????????}
????????
for(i?=?0;?i?<?n;?i++)
????????????make_set(i);
????????
for(i?=?0;?i?<?m;?i++)
????????{
????????????scanf("%d",?&t);
????????????scanf("%d",?&x);
????????????
for(j?=?1;?j?<?t;?j++){
????????????????scanf("%d",?&y);
????????????????union_set(x,?y);
????????????????x?=?y;
????????????}
????????}
????????x?=?find_set(0);/*找到0所在的樹的樹根*/
????????
//int?ans?=?0;
????????
//for(i?=?0;?i?<?n;?i++)
????????
//????if(pa[i]?==?x)
????????
//????????ans++;
????????
//cout?<<?ans?<<?endl;
????????cout?<<?num[x]?<<?endl;
????}
????
return?0;
}

?

?測試數據:

100 4 2 1 2 5 10 13 11 12 14 2 0 1 2 99 2 200 2 1 5 5 1 2 3 4 5 1 0?0 0?

轉載于:https://www.cnblogs.com/ktyanny/archive/2009/12/09/1620304.html

超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生

總結

以上是生活随笔為你收集整理的POJ 1611 The Suspects (并查集)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲一区二区观看 | 久久亚洲影院 | 97avcc| 欧美日韩亚洲国产精品 | 久久精品视频中文字幕 | 色噜噜一区二区三区 | 久久er99热精品一区二区 | 亚洲性影院 | 久久加久久 | 午夜生活片 | 国产精品久久久久影院色老大 | 日韩插插| 成人国产在线视频 | 婷婷丁香色 | 色噜噜狠狠一区二区三区 | 亚洲国产日韩一区 | xxx黄色片| 丰满秘书被猛烈进入高清播放在 | 亚洲自拍电影 | 免费在线观看黄 | 国产无码久久精品 | 国产精品一区二区精品 | 夜夜操影视 | 手机在线看片 | 成人在线视频一区 | 国产最新网址 | 女人高潮特级毛片 | 无码人妻精品一区二区三区99v | 中文字幕日本在线观看 | 亚洲 在线 | 免费黄色在线视频 | 亚洲一区二区黄片 | 奇米在线播放 | 超碰在线98 | 五月天婷婷激情视频 | 免费的黄色av | 久久久久久久偷拍 | av网站在线观看免费 | 色之久久综合 | 成人影片在线播放 | 天堂在线视频免费观看 | 91久久久久久久久久久久久 | 强乱中文字幕av一区乱码 | 一区二区精 | 色涩涩 | 亚洲午夜视频 | 日韩久久一区 | 亚洲同性gay激情无套 | 性欧美熟妇videofreesex | av片观看 | 狠狠干很很操 | 大地资源影视在线播放观看高清视频 | 精品视频在线免费 | 国产白丝av | 日韩在线观看第一页 | 国产日产精品一区二区三区四区 | 青青草原亚洲 | 国产女女调教女同 | 爱福利视频一区二区 | 丰满少妇乱子伦精品看片 | 日本福利视频导航 | 草一色| 免费观看在线播放 | 免费av一级 | 精品国产自在精品国产精小说 | 天天摸夜夜添 | 日本不卡高字幕在线2019 | www.久久久 | 中文亚洲av片在线观看 | 伊人亚洲影院 | 又爽又黄又无遮挡 | 欧美 日韩 国产 在线 | 国产乱子伦精品无码专区 | 实拍澡堂美女洗澡av | 色婷婷精品视频 | 中文字幕精品一区 | 亚洲视频欧洲视频 | 黄色大全免费观看 | 欧美一级淫片免费视频魅影视频 | 欧美日韩首页 | 东北老女人av | 叼嘿视频在线免费观看 | 日本吃奶摸下激烈网站动漫 | 中文在线视频 | 亚洲大尺度在线观看 | 国产精品黄视频 | 男人天堂aaa | 黄色三级大片 | 日日爱av| 无码人妻精品中文字幕 | 久热国产视频 | 经典三级久久 | 亚洲人成电影一区二区在线 | 欧美日韩国产在线一区 | 9999re| 亚洲一区二区三区人妻 | 外国黄色网 | 91性色| 日韩在线免费播放 |