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 ...
随机推荐
- Ajax 新建对象
XMLHttpRequest对象是Ajax的基础,用于后台与服务器进行数据交互. 新的浏览器支撑XMLHttpRequest,而旧的浏览器不支持. var vari; if(window.XMLHtt ...
- python 从filelist.txt中拷贝文件到另一文件夹中
#! python #coding:utf-8 ##!/usr/bin/python # Filename : fileCp.py import sys import os import shutil ...
- map()实现zip()功能
c = (map(lambda x,y:(x,y),[1,2,3],["abd","def","ghi"]))print(list(c)) ...
- tomcat 查看和修改内存
为了解决tomcat在大进行大并发请求时,出现内存溢出的问题,请修改tomcat的内存大小,其中分为以下两种方式: 一.使用 catalina.bat 等命令行方式运行的 tomcat 查看系统最大支 ...
- BZOJ5178[Jsoi2011]棒棒糖——主席树
题目描述 Coffee的世界里也是有棒棒糖卖的,Coffee买了N(1≤N≤50000)只连着的.这N只棒棒糖包裹在小塑料袋中,排成 一列,相邻的两只棒棒糖的塑料袋是接起来的.为了方便,我们把棒棒糖从 ...
- MT【230】一道代数不等式
设$a,b,c>0,$满足$a+b+c\le abc$证明:$\dfrac{1}{\sqrt{1+a^2}}+\dfrac{1}{\sqrt{1+b^2}}+\dfrac{1}{\sqrt{1+ ...
- JOISC 2017 自然公园
吐槽 YMD的课件是真的毒,YYB的也很毒. 题目链接 LOJ sol 我是一个一个Subtask做的... Subtask 1 \(O(n^2)\)枚举每两个点有没有边即可. Subtask 2 链 ...
- luogu3295 萌萌哒 (并查集+ST表)
如果给相同的位置连边,最后联通块数是n,最后答案就是$9*10^{n-1}$ 但直接连边是$O(n^2)$的 所以事先处理出一个ST表,每次O(1)地给那个ST表连边 最后再一点一点下放,就是把在这层 ...
- bzoj2599/luogu4149 [IOI2011]Race (点分治)
点分治.WA了一万年. 重点就是统计答案的方法 做法一(洛谷AC bzojWA 自测WA): 做点x时记到x距离为k的边数最小值为dis[k],然后对每一对有值的dis[i]和dis[K-i],给an ...
- luogu4360 锯木厂选址 (斜率优化dp)
设: sw[i]为1..i的w之和 sd[i]为1到i的距离 cost[i]为把第一个锯木厂建在i带来的花费 all[i,j]为把i..j所有木头运到j所需要的花费 所以$all[i,j]=cost[ ...