HDU 1233 还是畅通工程 (最小生成树 )
Input测试输入包含若干测试用例。每个测试用例的第1行给出村庄数目N ( < 100 );随后的N(N-1)/2行对应村庄间的距离,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间的距离。为简单起见,村庄从1到N编号。
当N为0时,输入结束,该用例不被处理。
Output对每个测试用例,在1行里输出最小的公路总长度。
Sample Input
- 3
- 1 2 1
- 1 3 2
- 2 3 4
- 4
- 1 2 1
- 1 3 4
- 1 4 1
- 2 3 3
- 2 4 2
- 3 4 5
- 0
Sample Output
- 3
- 5
题解:套模板
还是菜得一P啊
- #include <iostream>
- #include <algorithm>
- using namespace std;
- const int maxn=;
- int n,res,m;
- int par[maxn];
- struct node
- {
- int u,v,w;
- }es[maxn];
- int cmp(node x,node y)
- {
- return x.w<y.w;
- }
- void init()
- {
- for(int i=;i<maxn;i++) par[i]=i;
- }
- int Find(int x)
- {
- if(par[x]==x) return x;
- else return Find(par[x]);
- }
- int deal()
- {
- init();
- sort(es,es+m,cmp);
- res=;
- for(int i=;i<m;i++){
- int u=es[i].u,v=es[i].v,w=es[i].w;
- if(Find(u)==Find(v)) continue;
- par[Find(u)]=Find(v);
- res+=w;
- }
- return res;
- }
- int main()
- {
- while(cin>>n&&n){
- m=n*(n-)/;
- for(int i=;i<m;i++){
- cin>>es[i].u>>es[i].v>>es[i].w;
- }
- cout<<deal()<<endl;
- }
- return ;
- }
。。。。。。
- #include <iostream>
- #include <algorithm>
- #include <cstring>
- #include <cstdio>
- #include <vector>
- #include <cstdlib>
- #include <iomanip>
- #include <cmath>
- #include <ctime>
- #include <map>
- #include <set>
- #include <queue>
- using namespace std;
- #define lowbit(x) (x&(-x))
- #define max(x,y) (x>y?x:y)
- #define min(x,y) (x<y?x:y)
- #define MAX 100000000000000000
- #define MOD 1000000007
- #define pi acos(-1.0)
- #define ei exp(1)
- #define PI 3.141592653589793238462
- #define INF 0x3f3f3f3f3f
- #define mem(a) (memset(a,0,sizeof(a)))
- typedef long long ll;
- ll gcd(ll a,ll b){
- return b?gcd(b,a%b):a;
- }
- bool cmp(int x,int y)
- {
- return x>y;
- }
- const int N=;
- const int mod=1e9+;
- int f[N];
- struct edge
- {
- int u,v,w;
- }a[N];
- void init()
- {
- for(int i=;i<=N;i++)
- f[i]=i;
- }
- int find1(int x)
- {
- if(x!=f[x])
- f[x]=find1(f[x]);
- return f[x];
- }
- bool cmp1(edge a,edge b)
- {
- return a.w<b.w;
- }
- int main()
- {
- std::ios::sync_with_stdio(false);
- int n,m;
- while(scanf("%d",&n)&&n){
- init();
- m=n*(n-)/;
- for(int i=;i<m;i++)
- scanf("%d %d %d",&a[i].u,&a[i].v,&a[i].w);
- sort(a,a+m,cmp1);
- int s=;
- for(int i=;i<m;i++){
- int u=a[i].u,v=a[i].v,w=a[i].w;
- if(find1(u)==find1(v)) continue;
- f[find1(u)]=find1(v);
- s+=w;
- }
- printf("%d\n",s);
- }
- return ;
- }
HDU 1233 还是畅通工程 (最小生成树 )的更多相关文章
- hdu 1233 还是畅通工程 最小生成树(prim算法 + kruskal算法)
还是畅通工程 Time Limit: 4000/2 ...
- HDU 1233 还是畅通工程 (最小生成树)
还是畅通工程 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- HDU 1233.还是畅通工程-最小生成树(Prime)
还是畅通工程 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- (step6.1.5)hdu 1233(还是畅通工程——最小生成树)
题目大意:输入一个整数n,表示有n个村庄,在接下来的n*(n-1)/2中,每行有3个整数beigin.end.weight,分别表示路的起始村庄,结束村庄和村庄之间的距离. 求索要修的路的最短距离 解 ...
- HDU 1233 还是畅通工程(最小生成树,prim)
题意:中文题目 思路:prim实现,因为有n*(n-1)/2条边,已经是饱和的边了,prim比较合适. (1)将点1置为浏览过,点1可以到达其他每个点,所以用low[i]数组记录下目前到达i点的最小长 ...
- HDU.1233 还是畅通工程(Prim)
HDU.1233 还是畅通工程(Prim) 题意分析 首先给出n,代表村庄的个数 然后出n*(n-1)/2个信息,每个信息包括村庄的起点,终点,距离, 要求求出最小生成树的权值之和. 注意村庄的编号从 ...
- hdu 1233 还是畅通工程 (最小生成树)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1233 还是畅通工程 Time Limit: 4000/2000 MS (Java/Others) ...
- HDU 1233 还是畅通工程(Kruskal算法)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1233 还是畅通工程 Time Limit: 4000/2000 MS (Java/Others) ...
- hdu 1233 还是畅通工程 并查集or最小生成树
某省调查乡村交通状况,得到的统计表中列出了任意两村庄间的距离.省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可),并要求铺设的公路 ...
- hdu 1233:还是畅通工程(数据结构,图,最小生成树,普里姆(Prim)算法)
还是畅通工程 Time Limit : 4000/2000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submis ...
随机推荐
- Redis和Memcache的区别是什么
Redis和Memcache都是内存数据库,但它们之间还是有区别的,跟着ytkah看看Redis和Memcache的区别吧 Redis 支持多种数据结构,如string,list,dict,set,z ...
- Dockerfile语法解析
Dockfile介绍 从上到下依次执行 每次执行一条指令就创建一个镜像层 第一条指令必须是FROM 表示需要构建的镜像是由哪个镜像为基础镜像 后续的指令运行于此基准镜像所提供的运行环境 可以 ...
- PXE安装操作系统
TFTP服务 用PXE安装操作系统依赖于DHCP服务和TFTP服务 网卡一般都内置的TFTP客户端的程序 systemctl enable tftp systemctl enable dhc ...
- node学习系列 搭建express
搭建express express官网API http://expressjs.com/zh-cn/ 1.在文件夹下新建一个packages.json文件 内容为: {} 然后执行 yarn add ...
- git 查看某个文件的修改记录
有几种方式, (1)如果是在linux环境下,比如centos,ubuntu之类的,建议安装tig命令 炒鸡好用,tig后面可以跟文件或者文件夹,比如: (1.1)tig dir_name (1.2 ...
- git 不区分文件大小写的处理
- gem安装出错了
1.首先是SSL出错. SSL 证书错误 正常情况下,你是不会遇到 SSL 证书错误的,除非你的 Ruby 安装方式不正确. 如果遇到 SSL 证书问题,你又无法解决,请修改 ~/.gemrc 文件, ...
- Python Shell 中敲击方向键显示「^[[C^[[D],问题解决
碰到问题后,在网上搜索. 有帖子建议:yum install -y ncurses-devel,我这个2.7.13版本的在Linux下不行.估计是解决python3.x的方案. 尝试网上建议的,装了 ...
- asp.net拦截器
一 拦截器又称过滤器. asp.net mvc本身是自带3种拦截器:Action拦截器.Result拦截器.Exception拦截器. 应用中常见的拦截器有日志拦截器(Action拦截器)和异常处理拦 ...
- mx:Panel (面板容器) mx:Button (按钮) 默认大小
1.默认组件大小 <mx:Panel title="默认的面板容器大小和按钮控件大小"> <!-- 使用控件大小默认值 --> <mx:Button ...