HDU 1232 通畅工程
来源:互联网 发布:软件测试工程师 英文 编辑:程序博客网 时间:2024/06/02 16:43
畅通工程
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
4 21 33 34 31 25 21 32 31 203 5999 0
109982
并查集由一个整数型的数组和两个函数构成。数组pre[]记录了每个点的前导点是什么,函数find是查找,join是合并。
int pre[1000 ];
int find(int x) //查找根节点
{
int r=x;
while ( pre[r ] != r ) //返回根节点 r
r=pre[r ];
int i=x , j ;
while( i != r ) //路径压缩
{
j = pre[ i ]; // 在改变上级之前用临时变量 j 记录下他的值
pre[ i ]= r ; //把上级改为根节点
i=j;
}
return r ;
}
void join(int x,int y) //判断x y是否连通,
//如果已经连通,就不用管了 //如果不连通,就把它们所在的连通分支合并起,
{
int fx=find(x),fy=find(y);
if(fx!=fy)
pre[fx ]=fy;
}
#include<stdio.h>#include<string.h>int pre[1010],b[1001];int find(int x) //查找根节点{ int r=x; while(pre[r]!=r) //返回根节点 r r=pre[r]; int i=x,j; while(i!=r) //路径压缩 { j=pre[i]; pre[i]=r; i=j; } return r;}void join(int x,int y) //判断x y是否连通,{ //如果已经连通,就不用管了 //如果不连通,就把它们所在的连通分支合并起, int fx=find(x); int fy=find(y); if(fx!=fy) pre[fx]=fy;}int main(){ int m,n; while(~scanf("%d",&n)) { if(n==0) break; scanf("%d",&m); int t,i,x,y,count=0; for(i=1; i<=n; i++) pre[i]=i; for(i=1;i<=m; i++) { scanf("%d %d",&x,&y); join(x,y); } memset(b,0,sizeof(b)); for(i=1; i<=n; i++) { b[find(i)]=1; //查找有多少个根节点 count+=b[i]; //计数 } printf("%d\n",count-1); } return 0;}
- HDU 1232 通畅工程
- Hdu 1863 - 通畅工程
- HDU 1863 通畅工程
- hdoj 1232 通畅工程
- Hdu 1233 - 还是通畅工程
- Hdu 1879 - 继续通畅工程
- 并查集详解(HDU 1232通畅工程)
- HDU 1874 通畅工程续(Dijkstra)
- HDU 1875-通畅工程再续
- 通畅工程
- hdu 1874 通畅工程续(最短路模板)
- [HDU](1233)还是通畅工程 ---最小生成树(图)
- HDU_1232通畅工程
- HDN通畅工程
- HDU1232-通畅工程
- 通畅工程问题
- hdu1232通畅工程
- 还是通畅工程(HDU1233)
- 服务器被攻击了!
- SAP BW create custom Datasource
- Thinkphp 关于Behavior的理解
- 好看的照片墙效果实现(RecyclerView+Cardview+Palette)
- sessionStorage 、localStorage 和 cookie 之间的区别(转)
- HDU 1232 通畅工程
- 【51单片机】A/D(1)
- 《互联网+智能家居--传统家居颠覆与重构》(陈根)读书笔记及总结
- AFNetworking 支持cookies的解决方案
- 【C语言】自定义连接两个字符串函数
- getJSON 2 取值
- 类中静态成员与友元
- strrpos.php
- 记录一次使用DDNS通过域名访问服务器的过程