BZOJ1050 [HAOI2006]旅行
其实这道题根本不用最短路算法...
我们可以就把边从小到大排序,那么只需要枚举大小两个端点,把中间的边都加进去判断联通性即可.
判断联通性显然用的是并查集.
#include <cstdio>
#include <algorithm>
struct DJSET{
struct{
int fa,rk;
} p[505];
int find(int k){ return p[k].fa?p[k].fa=find(p[k].fa):k; }
inline void merge(int a,int b){
a=find(a),b=find(b);
if(a==b) return;
if(p[a].rk<p[b].rk) std::swap(a,b);
p[b].fa=a;
if(p[a].rk==p[b].rk) ++p[a].rk;
}
} set[5005];
struct eg{
int f,t,l;
inline void read(){
scanf("%d%d%d",&f,&t,&l);
}
} Es[5005];
int gcd(int a,int b){
if(a) return gcd(b%a,a);
return b;
}
bool cmp(const eg& a,const eg& b){
return a.l<b.l;
}
int m,n,i,j,s,t;
int FA,FB,FC,FA1,FB1,FC1;
inline void reduce(){
FC=gcd(FA,FB);
FA/=FC,FB/=FC;
}
int main(){
scanf("%d%d",&n,&m);
for(i=0;i<m;++i) Es[i].read();
std::sort(Es,Es+m,cmp);
scanf("%d%d",&s,&t);
FA1=1000;
for(i=0;i<m;++i){
for(j=i;j<m;++j){
set[i].merge(Es[j].f,Es[j].t);
if(set[i].find(s)==set[i].find(t)){
FA=Es[j].l,FB=Es[i].l;
reduce();
if(FA*FB1<FB*FA1){
FA1=FA;
FB1=FB;
}
break;
}
}
}
if(FB1==0) printf("IMPOSSIBLE"); else{
if(FB1==1) printf("%d\n",FA1); else printf("%d/%d\n",FA1,FB1);
}
return 0;
}
其实有个小优化:当所有边都加入而不联通时直接退出IMPOSSIBLE.
然后哎唷我擦快了不少...
#include <cstdio>
#include <algorithm>
struct DJSET{
struct{
int fa,rk;
} p[505];
int find(int k){ return p[k].fa?p[k].fa=find(p[k].fa):k; }
inline void merge(int a,int b){
a=find(a),b=find(b);
if(a==b) return;
if(p[a].rk<p[b].rk) std::swap(a,b);
p[b].fa=a;
if(p[a].rk==p[b].rk) ++p[a].rk;
}
} set[5005];
struct eg{
int f,t,l;
inline void read(){
scanf("%d%d%d",&f,&t,&l);
}
} Es[5005];
int gcd(int a,int b){
if(a) return gcd(b%a,a);
return b;
}
bool cmp(const eg& a,const eg& b){
return a.l<b.l;
}
int m,n,i,j,s,t;
int FA,FB,FC,FA1,FB1,FC1;
inline void reduce(){
FC=gcd(FA,FB);
FA/=FC,FB/=FC;
}
int main(){
scanf("%d%d",&n,&m);
for(i=0;i<m;++i) Es[i].read();
std::sort(Es,Es+m,cmp);
scanf("%d%d",&s,&t);
FA1=1000;
for(i=0;i<m;++i){
for(j=i;j<m;++j){
set[i].merge(Es[j].f,Es[j].t);
if(set[i].find(s)==set[i].find(t)){
FA=Es[j].l,FB=Es[i].l;
reduce();
if(FA*FB1<FB*FA1){
FA1=FA;
FB1=FB;
}
break;
}
}
if(FB1==0){
printf("IMPOSSIBLE\n");
return 0;
}
}
if(FB1==1) printf("%d\n",FA1); else printf("%d/%d\n",FA1,FB1);
return 0;
}
由于空间够大我还偷了个懒没有每次memset一遍...然后就出现了奇异的景象:
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
2W多KB的那个SB就是我.
BZOJ1050 [HAOI2006]旅行的更多相关文章
- BZOJ1050 HAOI2006旅行(最小生成树+LCT)
暴力枚举路径中权值最小边是哪个,然后求出边权不小于它的边的最小生成树,即可保证该路径上最大值最小.暴力当然可以过,这里使用LCT维护.注意数据中有自环. #include<iostream> ...
- bzoj1050: [HAOI2006]旅行comf
Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...
- [BZOJ1050] [HAOI2006] 旅行comf (Kruskal, LCT)
Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...
- bzoj1050[HAOI2006]旅行comf(枚举+贪心+并查集)
Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...
- BZOJ1050: [HAOI2006]旅行comf(并查集 最小生成树)
Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4021 Solved: 2257[Submit][Status][Discuss] Descript ...
- [BZOJ1050][HAOI2006]旅行comf 枚举+并查集
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1050 将边排序,枚举边权最小的边,依次加边直到S和T连通,更新答案. #include&l ...
- [bzoj1050 HAOI2006] 旅行comf (kruskal)
传送门 Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得 ...
- BZOJ1050 [HAOI2006]旅行comf[并查集判图连通性]
★ Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得路径 ...
- 【BZOJ1050】[HAOI2006]旅行
[BZOJ1050][HAOI2006]旅行 题面 bzoj 洛谷 题解 先将所有边从小往大排序 枚举钦定一条最小边 再枚举依次枚举最大边,如果两个点联通了就\(break\)统计答案即可 代码 #i ...
随机推荐
- NLP的两种工具的java版使用:复旦FudanNLP,中科院计算所ICTCLAS2013
编程语言:java 三种工具的简要介绍: FudanNLP google project上的介绍是: FudanNLP主要是为中文自然语言处理而开发的工具包,也包含为实现这些任务的机器学习算法和数据集 ...
- /WEB-INF/userManage.jsp(31,82) Unterminated ${ tag
这个错误是说明${}少写了一半. Unterminated有这个的意思是你的jsp语法有错误
- u11-nav02
header:before, header:after ,.navigation:before, .navigation:after,.nav-row:before, .nav-row:after,. ...
- 【BZOJ】3527: [Zjoi2014]力(fft+卷积)
http://www.lydsy.com/JudgeOnline/problem.php?id=3527 好好的一道模板题,我自己被自己坑了好久.. 首先题目看错.......什么玩意.......首 ...
- hdu1247 字典树
开始以为枚举会超时,因为有50000的词.后来试了一发就过了.哈哈.枚举没一个单词,将单词拆为2半,如果2半都出现过,那就是要求的. #include<stdio.h> #include& ...
- MyEclipse 开发 Web项目发布到 Tomcat 下的Root 目录
通常情况下,Web项目是发布到Tomcat下的webapps文件目录下的 . 例如:Web应用项目名称为:stock,则部署到tomcat后,是部署在tomcat/webapps/stock中,网址为 ...
- SQL Network Interfaces, error: 50 - 发生了 Local Database Runtime 错误。无法创建自动实例。
今天在用VS2013自带的LocalDB调整数据库时出错,在网上也搜到许多方案,如卸载SQLServer LocalDB的程序.重新创建实例等都没有解决我的问题,也重新修改以及修复Vs,问题依旧存在, ...
- 【POJ 3020】Antenna Placement(二分图匹配)
相当于用1*2的板覆盖给定的h*w的格子里的点,求最少的板.可以把格子相邻的分成两个集合,如下图,0为一个集合,1的为一个,也就是(行数+列数)为奇数的是一个集合,为偶数的为另一个集合.1010101 ...
- str和repr的
尽管str(),repr()和``运算在特性和功能方面都非常相似,事实上repr()和``做的是完全一样的事情,它们返回的是一个对象的“官方”字符串表示,也就是说绝大多数情况下可以通过求值运算(使用内 ...
- 如何使用lessc编译.less文件
LESS :一种动态样式语言. LESS 将 CSS 赋予了动态语言的特性,如 变量, 继承, 运算, 函数. LESS 既可以在 客户端 上运行 (支持IE 6+, Webkit, Firefox) ...