其实这道题根本不用最短路算法...

我们可以就把边从小到大排序,那么只需要枚举大小两个端点,把中间的边都加进去判断联通性即可.

判断联通性显然用的是并查集.

#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一遍...然后就出现了奇异的景象:

Submit 1737
User(Submit) 735
User(Solved) 702
AC 871
WA 460
TLE 196
MLE 3
OLE 6
RE 143
CE 58
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
AC[50%]
 
WA[26%]
 
TLE[11%]
 
MLE[0%]
 
OLE[0%]
 
RE[8%]
 
CE[3%]
No. RunID User Memory Time Language Code_Length Submit_Time
241 546203 absi2011 1468 KB 1076 MS C++ 2608 B 2014-02-14 16:51:06
242 695809 zhengly123 1824 KB 1076 MS C++ 1730 B 2014-07-15 14:58:06
243 473121 sth1997 864 KB 1088 MS C++ 1321 B 2013-08-29 10:59:59
244 967344(2) tmzbot 20616 KB 1116 MS C++ 1311 B 2015-05-08 14:26:09
245 312288 Maigo 1352 KB 1144 MS C++ 1060 B 2012-10-06 16:16:30
246 234103 Oct_Gap201 372 KB 1152 MS Pascal 4710 B 2012-03-27 16:40:05
247 786906 Nano_Ape 1480 KB 1152 MS C++ 1705 B 2014-11-26 14:35:22
248 6697(2) Sachs 700 KB 1153 MS Pascal 2155 B 2009-09-09 18:39:30
249 221303 TSZWL 368 KB 1156 MS Pascal 4662 B 2012-03-10 16:07:32
250 244488(2) bill125 368 KB 1156 MS Pascal 4662 B 2012-04-16 23:08:22
251 214563(2) sbsbsbsb 368 KB 1160 MS Pascal 4670 B 2012-02-28 21:34:20
252 197945 This_poet 1396 KB 1168 MS C++ 1564 B 2012-02-01 17:13:54
253 67605 nathenqian 268 KB 1183 MS C++ 1737 B 2010-12-11 14:49:13
254 68313 cfttcc 860 KB 1183 MS Pascal 1751 B 2010-12-14 13:33:07
255 75681 crfish 600 KB 1184 MS Pascal 1662 B 2011-02-25 23:25:16
256 29182 wu3412790 620 KB 1184 MS Pascal 1381 B 2010-06-11 17:00:14
257 661385 RealCS 1396 KB 1188 MS C++ 1560 B 2014-05-30 15:37:42
258 12275 thegreysky 320 KB 1199 MS C++ 1523 B 2010-03-09 22:25:46
259 6500 zr_1234 684 KB 1201 MS Pascal 1957 B 2009-09-01 18:26:15
260 460098 Ruchiose 1332 KB 1212 MS C++ 2924 B 2013-08-02 17:20:09

[TOP]  [STATUS]  [PREV]  [NEXT]

2W多KB的那个SB就是我.

BZOJ1050 [HAOI2006]旅行的更多相关文章

  1. BZOJ1050 HAOI2006旅行(最小生成树+LCT)

    暴力枚举路径中权值最小边是哪个,然后求出边权不小于它的边的最小生成树,即可保证该路径上最大值最小.暴力当然可以过,这里使用LCT维护.注意数据中有自环. #include<iostream> ...

  2. bzoj1050: [HAOI2006]旅行comf

    Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...

  3. [BZOJ1050] [HAOI2006] 旅行comf (Kruskal, LCT)

    Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...

  4. bzoj1050[HAOI2006]旅行comf(枚举+贪心+并查集)

    Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...

  5. BZOJ1050: [HAOI2006]旅行comf(并查集 最小生成树)

    Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4021  Solved: 2257[Submit][Status][Discuss] Descript ...

  6. [BZOJ1050][HAOI2006]旅行comf 枚举+并查集

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1050 将边排序,枚举边权最小的边,依次加边直到S和T连通,更新答案. #include&l ...

  7. [bzoj1050 HAOI2006] 旅行comf (kruskal)

    传送门 Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得 ...

  8. BZOJ1050 [HAOI2006]旅行comf[并查集判图连通性]

    ★ Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得路径 ...

  9. 【BZOJ1050】[HAOI2006]旅行

    [BZOJ1050][HAOI2006]旅行 题面 bzoj 洛谷 题解 先将所有边从小往大排序 枚举钦定一条最小边 再枚举依次枚举最大边,如果两个点联通了就\(break\)统计答案即可 代码 #i ...

随机推荐

  1. metaspolit 基础

    在kali中使用metasploit,需要先开启PostgreSQL数据库服务和metasploit服务,然后就可以完整的利用msf数据库查询exploit和记录了.这一点比bt5要方便很多,所以现在 ...

  2. Spring-涉及到的设计模式汇总

    1. 简单工厂 又叫做静态工厂方法(StaticFactory Method)模式,但不属于23种GOF设计模式之一. 简单工厂模式的实质是由一个工厂类根据传入的参数,动态决定应该创建哪一个产品类. ...

  3. Hibernate-一对多的关系维护

    一对多 和多对一 一般是看需求来确定的,很多时候都是设置成双向的 举个最最普通的离子 :一个班级里面有多个学生 多个学生属于一个班级 从学生表来看 就是多对一的关系 从班级表来看就是一对多的关系 需求 ...

  4. Spring POST

    Spring POST+表单对象如果数据格式不正确,则页面直接报400.页面没有反应,烦啊

  5. 【poj3608】 Bridge Across Islands

    http://poj.org/problem?id=3608 (题目链接) 题意 求两凸包间最短距离 Solution 难写难调,旋转卡壳,还真是卡死我了. 先分别选出两凸包最上点和最下点,从这两点开 ...

  6. Dedecms include\dialog\select_soft_post.php Upload Any Files To The Specified Directory Via Variable Not Initial Flaw Bypass Extension Defence

    目录 . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 综合来说,这个漏洞的根源是"register_globals = on& ...

  7. wifi与wimax

    这几天在看文献中看到802.11a,802.11n和802.16e这几种无信通信协议标准,在网上查了相关资料后,看到有个帖子总结得不错,故将其转载过来. 转:http://blog.csdn.net/ ...

  8. appium按钮定位,去掉弹出框

    #coding=utf-8 这个一定要加上,不然脚本中注释中都不能有中文 ''' Created on 2015年7月2日 @author: liujuan ''' import sys reload ...

  9. MyEclipse2014中SVN的使用方法

    MyEclipse中的SVN操作手册 1.导入项目 点击工具栏上的[File-Import],进入下图 (如果你的对话框中没有SVN这一条目,可能是因为你没有安装SVN插件,请安装完成后,在看这篇博客 ...

  10. c++模板库(简介)

    目 录 STL 简介 ......................................................................................... ...