POJ1287 Networking【最小生成树】
题意:
给出n个节点,再有m条边,这m条边代表从a节点到b节点电缆的长度,现在要你将所有节点都连起来,并且使长度最小
思路:
这是个标准的最小生成树的问题,用prim的时候需要注意的是他有重边,取边最小的那条加入图里就可以了,但是kruskal可以忽略这个问题
代码:
prim:
#include <iostream>
#define maxn 55
#define inf 1<<29
using namespace std; int map[maxn][maxn];
int n,m; void prim()
{
int d[maxn],vis[maxn];
int i,v,j,minn;
for(i=;i<=n;i++){
vis[i]=;
d[i]=map[][i];
}
for(i=;i<=n;i++)
{
minn=inf;
for(j=;j<=n;j++)
if(!vis[j] && d[j]<minn)
{
minn=d[j];
v=j;
}
vis[v]=j;
for(j=;j<=n;j++)
{
if(!vis[j] && map[v][j]<d[j])
d[j]=map[v][j];
}
}
for(d[]=,i=;i<=n;i++)
d[]+=d[i];
cout<<d[]<<endl;
} int main()
{
int i,j,a,b,c;
while(cin>>n,n)
{
cin>>m;
for(i=;i<=n;i++)
{
for(j=;j<=n;j++)
if(i!=j) map[i][j]=inf;
else map[i][j]=;
}
for(i=;i<m;i++)
{
cin>>a>>b>>c;
if(map[a][b]>c) map[a][b]=map[b][a]=c;
}
prim();
}
return ;
}
krusual:
#include <iostream>
#include <algorithm>
using namespace std; typedef struct
{
int s,t,w;
}Edge; Edge edge[];
int n,m,set[]; int cmp(const void * a,const void * b)
{
return (*(Edge *)a).w-(*(Edge *)b).w;
} int find(int x)
{
if(x==set[x]) return x;
int rt=find(set[x]);
set[x]=rt;
return set[x];
} bool Union(int x,int y)
{
int fx=find(x);
int fy=find(y);
if(fx==fy) return ;
set[fx]=fy;
return ;
} void kruskal()
{
int i,sum=;
for(i=;i<=m;i++)
{
if(Union(edge[i].s,edge[i].t))
{
sum+=edge[i].w;
}
}
cout<<sum<<endl;
} int main()
{
int i;
while(cin>>n,n)
{
for(i=;i<=n;i++)
set[i]=i;
cin>>m;
for(i=;i<=m;i++)
{
cin>>edge[i].s>>edge[i].t>>edge[i].w;
}
qsort(edge+,m,sizeof(edge[]),cmp);
kruskal();
}
return ;
}
POJ1287 Networking【最小生成树】的更多相关文章
- POJ 1287 Networking (最小生成树)
Networking Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit S ...
- poj-1287 Networking(Prim)
题目链接:http://poj.org/problem?id=1287 题目描述: 请先参考关于prim算法求最小生成树的讲解博客:https://www.cnblogs.com/LJHAHA/p/1 ...
- POJ 1287 Networking (最小生成树模板题)
Description You are assigned to design network connections between certain points in a wide area. Yo ...
- POJ1287 Networking
解题思路:Kruskal模板题,重复输入的情况,本题是无向图. 见代码: #include<cstdio> #include<algorithm> #include<cs ...
- poj图论解题报告索引
最短路径: poj1125 - Stockbroker Grapevine(多源最短路径,floyd) poj1502 - MPI Maelstrom(单源最短路径,dijkstra,bellman- ...
- 最小生成树 prime poj1287
poj1287 裸最小生成树 代码 #include "map" #include "queue" #include "math.h" #i ...
- 最小生成树练习1(克鲁斯卡尔算法Kruskal)
今天刷一下水题练手入门,明天继续. poj1861 Network(最小生成树)新手入门题. 题意:输出连接方案中最长的单根网线长度(必须使这个值是所有方案中最小的),然后输出方案. 题解:本题没有直 ...
- kuangbin最小生成树专题
网址:https://vjudge.net/contest/66965#overview 第一题: poj1251 裸最小生成树 #include<iostream> #include&l ...
- POJ 1287 Networking (最小生成树)
Networking 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/B Description You are assigned ...
随机推荐
- Apache虚拟主机
基本概述 虚拟Web主机 在同一台服务器中运行多个Web站点,其中每一个站点并不独立占用一台真正的计算机 httpd支持的虚拟主机类型 基于域名的虚拟主机 基于IP地址的虚拟主机 基于端口的虚拟主机 ...
- LOJ116 有源汇有上下界最大流(上下界网络流)
考虑有源汇上下界可行流:由汇向源连inf边,那么变成无源汇图,按上题做法跑出可行流.此时该inf边的流量即为原图中该可行流的流量.因为可以假装把加上去的那些边的流量放回原图. 此时再从原来的源向原来的 ...
- LAMP和LNMP去除index.php访问
使用TP或者Laravel开发的时候,后时候会遇到需要加index.php才能正常访问 LAMP解决方法 1.修改配置 打开配置文件(如:httpd.conf),找到你网站根目录的配置,将AllowO ...
- BZOJ4870 [六省联考2017] 组合数问题 【快速幂】
题目分析: 构造f[nk][r]表示题目中要求的东西.容易发现递推公式f[nk][r]=f[nk-1][r]+f[nk-1][(r-1)%k].矩阵快速幂可以优化,时间复杂度O(k^3logn). 代 ...
- 【POJ1456】Supermarket(贪心)
BUPT2017 wintertraining(16) #4 F POJ - 1456 题意 每个商品有过期日期和价格,每天可以卖一个商品,必须在过期前出售才能收益,求最大收益. 题解 贪心,按价格排 ...
- 【BZOJ3202】项链(莫比乌斯反演,Burnside引理)
[BZOJ3202]项链(莫比乌斯反演,Burnside引理) 题面 BZOJ 洛谷 题解 首先读完题目,很明显的感觉就是,分成了两个部分计算. 首先计算本质不同的珠子个数,再计算本质不同的项链个数. ...
- bzoj5280/luogu4376 MilkingOrder (二分答案+拓扑序)
二分答案建图,然后判环,就可以了. 字典序输出的话,只要做拓扑序的时候用优先队列来维护就可以了. (其实判环也可以用拓扑序...) #include<cstdio> #include< ...
- 【POJ3017】Cut the Sequence
题目大意:给定一个长度为 N 的序列,将序列划分成若干段,保证每段之和不超过 M,问所有段的最大值之和最小是多少. 题解:设 \(f[i]\) 表示前 i 个数满足上述条件的最优解,显然有状态转移方程 ...
- (大数 万进制) N! hdu1042
N! Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Total Subm ...
- 利用ansible-playbook从测试环境获取tomcat中java项目新版本发布到生产环境
一.环境描述 安装有ansible的服务器:192.168.13.45 测试环境服务器:192.168.13.49 /home/app/api-tomcat/webapps/api.war为测试环境新 ...