HDOJ 1863
#include<stdio.h>
#include<string.h>
int father[105],depth[105];
int dist[105],map[101][101];
int vis[105],n;
void init_B()
{
int i;
for(i = 1;i <= n;i ++)
{
father[i] = i;
depth[i] = 0;
}
}
int find(int x)
{
if(x == father[x])
return x;
return father[x] = find(father[x]);
}
void unit(int x,int y)
{
x = find(x);
y = find(y);
if(x == y)
return ;
if(depth[x] < depth[y])
father[x] = y;
else
{
if(depth[x] > depth[y])
father[y] = x;
else
{
father[x] = y;
depth[y]++;
}
}
}
void init()
{
int i;
memset(vis,0,sizeof(vis));
for(i = 1;i <= n;i ++)
dist[i] = map[1][i];
}
int main()
{
int m,i,j,k,a,b;
int min,cnt,cost,sum;
while(~scanf("%d%d",&m,&n) && m)
{
init_B();
sum = cnt = 0;
for(i = 1;i <= n;i ++)
{
for(j = 1;j <= n;j ++)
{
if(i != j)
{
map[i][j] = 1 << 30;
}
}
}
while(m--)
{
scanf("%d%d%d",&a,&b,&cost);
map[a][b] = map[b][a] = cost;
unit(a,b);
}
init();
for(i = 1;i <= n;i ++)
{
if(i == find(i))
cnt++;
if(cnt == 2)
break ;
}
if(cnt == 2)
{
printf("?\n");
continue ;
}
for(i = 0;i < n;i ++)
{
min = 1 << 30;
for(j = 1;j <= n;j ++)
{
if(!vis[j] && min > dist[j])
{
min = dist[j];
k = j;
}
}
vis[k] = 1;
if(min != 1 << 30)
sum += min;
for(j = 1;j <= n;j ++)
{
if(!vis[j] && dist[j] > map[k][j])
dist[j] = map[k][j];
}
}
printf("%d\n",sum);
}
return 0;
}
#include<string.h>
int father[105],depth[105];
int dist[105],map[101][101];
int vis[105],n;
void init_B()
{
int i;
for(i = 1;i <= n;i ++)
{
father[i] = i;
depth[i] = 0;
}
} int find(int x)
{
if(x == father[x])
return x;
return father[x] = find(father[x]);
} void unit(int x,int y)
{
x = find(x);
y = find(y);
if(x == y)
return ;
if(depth[x] < depth[y])
father[x] = y;
else
{
if(depth[x] > depth[y])
father[y] = x;
else
{
father[x] = y;
depth[y]++;
}
}
} void init()
{
int i;
memset(vis,0,sizeof(vis));
for(i = 1;i <= n;i ++)
dist[i] = map[1][i];
} int main()
{
int m,i,j,k,a,b;
int min,cnt,cost,sum;
while(~scanf("%d%d",&m,&n) && m)
{
init_B();
sum = cnt = 0;
for(i = 1;i <= n;i ++)
{
for(j = 1;j <= n;j ++)
{
if(i != j)
{
map[i][j] = 1 << 30;
}
}
}
while(m--)
{
scanf("%d%d%d",&a,&b,&cost);
map[a][b] = map[b][a] = cost;
unit(a,b);
}
init();
for(i = 1;i <= n;i ++)
{
if(i == find(i))
cnt++;
if(cnt == 2)
break ;
}
if(cnt == 2)
{
printf("?\n");
continue ;
}
for(i = 0;i < n;i ++)
{
min = 1 << 30;
for(j = 1;j <= n;j ++)
{
if(!vis[j] && min > dist[j])
{
min = dist[j];
k = j;
}
}
vis[k] = 1;
if(min != 1 << 30)
sum += min;
for(j = 1;j <= n;j ++)
{
if(!vis[j] && dist[j] > map[k][j])
dist[j] = map[k][j];
}
}
printf("%d\n",sum);
}
return 0;
}
HDOJ 1863的更多相关文章
- Kruskal HDOJ 1863 畅通工程
题目传送门 /* 此题为:HDOJ 1233 + HDOJ 1232 */ #include <cstdio> #include <algorithm> #include &l ...
- 最小生成树(HDOJ 1863)
畅通工程 http://acm.hdu.edu.cn/showproblem.php?pid=1863 1.Prim算法: Prim算法是由一个点(最初的集合)向外延伸,找到与集合相连权值最小的边, ...
- HDOJ 1863 prim算法 HDOJ 1879
#include<cstdio> #include<cstring> #define inf 0xffffff ][]; int ans; void prim(int n) { ...
- hdoj 1863 畅通工程 最小生成树---prime算法
题目: http://acm.hdu.edu.cn/showproblem.php?pid=1863 注意有可能出现无法生成树的情况. #include <iostream> #inclu ...
- hdoj 1863 畅通工程
并查集+最小生成树 畅通工程 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- MST最小生成树
首先,贴上一个很好的讲解贴: http://www.wutianqi.com/?p=3012 HDOJ 1233 还是畅通工程 http://acm.hdu.edu.cn/showproblem.ph ...
- 杭电hdoj题目分类
HDOJ 题目分类 //分类不是绝对的 //"*" 表示好题,需要多次回味 //"?"表示结论是正确的,但还停留在模块阶 段,需要理解,证明. //简单题看到就 ...
- HDOJ 题目分类
HDOJ 题目分类 /* * 一:简单题 */ 1000: 入门用:1001: 用高斯求和公式要防溢出1004:1012:1013: 对9取余好了1017:1021:1027: ...
- HDOJ 1009. Fat Mouse' Trade 贪心 结构体排序
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
随机推荐
- Web前端新人笔记之文本属性
前一段时间因工作时间减缓了更新笔记的时间.我也不知道有没有会观看并且能不能帮到一些初学者,这只是我的一些小随笔而已.当然我也希望的的每一篇随笔都可以帮到更多的想要学习前端开发的初学者们,更希望你们也可 ...
- 解决VS2008打开假死或者打开设计模式假死的问题
我昨天刚装完OFFICE 2010一直也没重启,vs2008是可以使用的.今早来到办公室,打开工程发现开了半天VS2008一般空白,查看应用程序显示正在运行,再查看进程发现里面多一个setup.exe ...
- asp.net mvc NPOI 生成Excel文件
private string PushToDown(string addtime) { DataTable dt = _bCreateCode.PushtoExcel(addtime); //1.实例 ...
- JDBC和DBUtils区别(查询时jdbc只能返回ResultSet需要po转vo,dbutils返回的BeanListHandler与BeanHandler对应集合与对象)
17:34 2013/6/7 JDBC //添加客户 public void addNewCustomer(Customer c) throws DAOException { Connection c ...
- hdu 3303 Harmony Forever (线段树 + 抽屉原理)
http://acm.hdu.edu.cn/showproblem.php?pid=3303 Harmony Forever Time Limit: 20000/10000 MS (Java/Othe ...
- css中table-layout:fixed 属性的用法
table-layout:fixed 属性的用法:如果想要一个table固定大小,里面的文字强制换行(尤其是在一长串英文文本,并且中间无空格分隔的情况下),以达到使过长的文字 不撑破表格的目的,一般是 ...
- CSS3制作下拉菜单
导航菜单其实是没有什么可说的,制作方法到处可见,今天这个案例本来不只是一个导 航,还有一个搜索表单的,可是为了偷懒,把搜索表单部分去掉了,就变成了一个CSS3 制作的下拉菜单.在这个导航中主要两点,一 ...
- PHP mysql_real_escape_string() 函数
定义和用法 mysql_real_escape_string() 函数转义 SQL 语句中使用的字符串中的特殊字符. 下列字符受影响: \x00 \n \r \ ' " \x1a 如果成功, ...
- Nginx完整配置说明
http://blog.csdn.net/marising/article/details/3979493 可以参考如下的完整例子 http://wiki.codemongers.com/NginxF ...
- POJ 3007 Organize Your Train part II(哈希链地址法)
http://poj.org/problem?id=3007 题意 :给你一个字符串,让你无论从什么地方分割,把这个字符串分成两部分s1和s2,然后再求出s3和s4,让你进行组合,看能出来多少种不同的 ...