HDU - 1232 畅通工程
注意:两个城市之间可以有多条道路相通,也就是说
3 3
1 2
1 2
2 1
这种输入也是合法的
当N为0时,输入结束,该用例不被处理。
#include<stdio.h>
int p[]; //用于描述没个数的上一级,保存当前坐标的上一级,上司
int find(int x)//用于查找 x 的老大,掌门人
{
int r=x,t,i,j;
while(p[r]!=r) //最后r即使x的老大
r=p[r];
t=x;
while(p[t]!=r) //这是利用已知的老大的坐标,压缩路径,将老大所有的手下的的手下的手下.....全部归到只是老大的下一级,为了方便各个小弟查询老大
{
i=p[t];
p[t]=r;
t=i;
}
return r;//返回老大的坐标
} int he(int x,int y)//用于将两个集合合并在一起
{
if(find(x)!=find(y))//查询两个数的老大,如果不同老大,将x的老大变成y的老大
{
p[find(y)]=p[find(x)];
return ; //返回1用于题目计算需要建的路(打架的次数)
}
return ;
} int main()
{
int n,m,x,y,i;
while(~scanf("%d%d",&n,&m)&&n)
{
int s=n-;//开始若有n个点,则需要修建n-1条路(打n-1次架)
for(i=;i<=n;i++)//初始化,把所有点都初始化成自己是自己的老大,自成一派
p[i]=i;
for(i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
if(he(x,y)==)s--;//返回1 则表示两个不同小弟是不同的老大,打了一架后,则需要打s-1次架。
}
/*
43 计算s还可以用,此时每个门派(集合)都归纳好了,开始看看有多少个不同的集合,即看看有多少个不同的老大,根据有多少个老大,这是
44 在开始看看要打多少次架(帮派间的斗争!!)有n个老大就要打n-1次架 (有n个集合就要n-1次修路)
45 可以用一个数组存储根,在查询有多少个根!
46
47 */
printf("%d\n",s);
}
}
自己敲一遍
#include<cstdio>
#include<algorithm> using namespace std; int p[]; int Find(int x)
{
int r = x, t, i; while(p[r] != r)
r = p[r]; t = x; while(p[t] != r)
{
i = p[t];
p[t] = r;
t = i;
} return r;
} int QQ(int x, int y)
{
if (Find(x) != Find(y))
{
p[Find(y)] = p[Find(x)];
return ;
}
return ;
} int main()
{
int n; while (scanf ("%d", &n), n != )
{
int i, m, num = n-; for (i = ; i <= n; i++)
p[i] = i; scanf ("%d", &m); int x, y; for (i = ; i < m ;i++)
{
scanf ("%d %d", &x, &y);
if (QQ(x, y) == )
num--; }
printf ("%d\n", num);
}
return ;
}
HDU - 1232 畅通工程的更多相关文章
- HDU 1232 畅通工程(道路连接)(裸并查集)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1232 畅通工程 Time Limit: 4000/2000 MS (Java/Others) ...
- hdu 1232 畅通工程(并查集算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1232 畅通工程 Time Limit: 4000/2000 MS (Java/Others) M ...
- HDU 1232(畅通工程)题解
以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] 给定一具有N个节点的图和其边集,求其集合数量. [题目分析] 并查集经典题...其实就是创建好并查集就行了.. [算法流程] 于 ...
- HDU 1232 畅通工程(模板——并查集)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1232 Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出 ...
- HDU 1232 畅通工程(并查集)
畅通工程 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem Des ...
- hdu 1232畅通工程
Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府"畅通工程"的目标是使全省任何两个城镇间都可以实现交通 ...
- HDU 1232 畅通工程(最小生成树+并查集)
畅通工程 Time Limit : 1000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Submissi ...
- HDU 1232 畅通工程 (并查集)
某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府“畅通工程”的目标是使全省任何两个城镇间都可以实现交通(但不一定有直接的道路相连,只要互相间接通过道路可达即可). ...
- hdu 1232:畅通工程(数据结构,树,并查集)
畅通工程 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- Ubuntu下使用vsftpd实现FTP
## 哈哈哈啊哈 被领导啪啪啪打脸,文件连在线打开都不行,你做事情的时候有没有考虑过别人使用时的感受!! 需求: 部门老大希望在内网搭建一个用于员工共享文件的系统. 很自然的就想到通过FTP去实现. ...
- spring自定义schema学习
[转载请注明作者和原文链接,欢迎讨论,相互学习.] 一.前言 1. 最近在学习dubbo,里边很多如provider.consumer.registry的配置都是通过spring自定义Schema来实 ...
- iOS 多任务
本文转自猫神的博客:https://onevcat.com/2013/08/ios7-background-multitask/ 写的没的说,分享给大家,一起学习! iOS7以前的Multitaski ...
- jqgrid no url reset
如果发现 jqgrid 在运行中出现次错误,可能是以下原因 $('#@(ViewBag.tabcid + "_grid")').jqGrid('navGrid', '#@(View ...
- python与shell的3种交互方式介绍
[目录] 1.os.system(cmd) 2.os.popen(cmd) 3.利用subprocess模块 4.subprocessor模块进阶 [概述] 考虑这样一个问题,有hello.py脚本, ...
- 关于java.lang.NoSuchMethodError: android.widget.RelativeLayout.setBackground的解决办法
今天用一个安卓4.0.4版本的手机测试手上的项目,发现logcat弹出这样一个提示“java.lang.NoSuchMethodError: android.widget.RelativeLayout ...
- 授权其他数据库用户kill session
授权其他数据库用户kill session kill session权限 CREATE OR REPLACE PROCEDURE P_KILL_SESSION(P_USER IN VARCHAR2, ...
- 函数Curry化
之前写过一个函数Curry化的小文章 那会儿对Curry化的理解不够深,平时遇到的需要Curry化的例子也比较少,今天,重新整理这个问题 函数Curry化,其实就是将一个参数非常多的函数,在大多数参数 ...
- Vue.js双向绑定的实现原理
Vue.js最核心的功能有两个,一是响应式的数据绑定系统,二是组件系统.本文仅探究几乎所有Vue的开篇介绍都会提到的hello world双向绑定是怎样实现的.先讲涉及的知识点,再参考源码,用尽可能少 ...
- Symbols
https://hacks.mozilla.org/2015/06/es6-in-depth-symbols/ <script> function w(wcon) { console.lo ...