UVA-11374 Airport Express (dijkstra+枚举)
题目大意:n个点,m条无向边,边权值为正,有k条特殊无向边,起止点和权值已知,求从起点到终点的边权值最小的路径,特殊边最多只能走一条。
题目分析:用两次dijkstra求出起点到任何一个点的最小权值,任何一个点到终点的最小权值,枚举每一条特殊边,取最小的权值。
代码如下:
# include<iostream>
# include<cstdio>
# include<queue>
# include<vector>
# include<cstring>
# include<algorithm>
using namespace std; const int INF=1<<29;
struct Node
{
int u,t;
Node(int _u,int _t):u(_u),t(_t){}
bool operator < (const Node &a) const {
return t>a.t;
}
};
struct Edge
{
int w,to,nxt;
};
Edge e[4005];
int n,head[505],d[2][505],path[2][505],vis[505],cnt; void add(int u,int v,int w)
{
e[cnt].to=v;
e[cnt].w=w;
e[cnt].nxt=head[u];
head[u]=cnt++;
} void dijkstra(int S,int id)
{
for(int i=0;i<=n;++i) path[id][i]=i;
fill(d[id],d[id]+n+1,INF);
d[id][S]=0;
priority_queue<Node>q;
memset(vis,0,sizeof(vis));
q.push(Node(S,0));
while(!q.empty())
{
Node u=q.top();
q.pop();
if(vis[u.u]) continue;
vis[u.u]=1;
for(int i=head[u.u];i!=-1;i=e[i].nxt){
if(d[id][e[i].to]>u.t+e[i].w){
d[id][e[i].to]=u.t+e[i].w;
path[id][e[i].to]=u.u;
if(!vis[e[i].to])
q.push(Node(e[i].to,d[id][e[i].to]));
}
}
}
} void print(int u)
{
if(path[0][u]==u)
printf("%d",u);
else{
print(path[0][u]);
printf(" %d",u);
}
} int main()
{
int S,E,m,a,b,c,flag=0;
while(~scanf("%d%d%d",&n,&S,&E))
{
if(flag)
printf("\n");
flag=1;
cnt=0;
memset(head,-1,sizeof(head));
scanf("%d",&m);
while(m--)
{
scanf("%d%d%d",&a,&b,&c);
add(a,b,c);
add(b,a,c);
}
dijkstra(S,0);
dijkstra(E,1);
int ans=d[0][E],ansa=-1,ansb;
scanf("%d",&m);
for(int i=1;i<=m;++i)
{
scanf("%d%d%d",&a,&b,&c);
if(d[0][a]<INF&&d[1][b]<INF&&d[0][a]+c+d[1][b]<ans){
ans=d[0][a]+d[1][b]+c;
ansa=a,ansb=b;
}
if(d[0][b]<INF&&d[1][a]<INF&&d[0][b]+c+d[1][a]<ans){
ans=d[0][b]+d[1][a]+c;
ansa=b,ansb=a;
}
}
if(ansa==-1){
print(E);
printf("\n");
}else{
print(ansa);
while(path[1][ansb]!=ansb){
printf(" %d",ansb);
ansb=path[1][ansb];
}
printf(" %d\n",ansb);
}
if(ansa==-1)
printf("Ticket Not Used\n");
else
printf("%d\n",ansa);
printf("%d\n",ans);
}
return 0;
}
UVA-11374 Airport Express (dijkstra+枚举)的更多相关文章
- UVA - 11374 Airport Express (Dijkstra模板+枚举)
Description Problem D: Airport Express In a small city called Iokh, a train service, Airport-Express ...
- UVa 11374 - Airport Express ( dijkstra预处理 )
起点和终点各做一次单源最短路, d1[i], d2[i]分别代表起点到i点的最短路和终点到i点的最短路,枚举商业线车票cost(a, b); ans = min( d1[a] + cost(a, b ...
- UVA 11374 Airport Express(枚举+最短路)
枚举每条商业线<a, b>,设d[i]为起始点到每点的最短路,g[i]为终点到每点的最短路,ans便是min{d[a] + t[a, b] + g[b]}.注意下判断是否需要经过商业线.输 ...
- UVA - 11374 - Airport Express(堆优化Dijkstra)
Problem UVA - 11374 - Airport Express Time Limit: 1000 mSec Problem Description In a small city c ...
- UVA 11374 Airport Express SPFA||dijkstra
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- UVA 11374 Airport Express 机场快线(单源最短路,dijkstra,变形)
题意: 给一幅图,要从s点要到e点,图中有两种无向边分别在两个集合中,第一个集合是可以无限次使用的,第二个集合中的边只能挑1条.问如何使距离最短?输出路径,用了第二个集合中的哪条边,最短距离. 思路: ...
- UVA 11374 Airport Express (最短路)
题目只有一条路径会发生改变. 常见的思路,预处理出S和T的两个单源最短路,然后枚举商业线,商业线两端一定是选择到s和t的最短路. 路径输出可以在求最短路的同时保存pa数组得到一棵最短路树,也可以用di ...
- UVA 11374 Airport Express(最短路)
最短路. 把题目抽象一下:已知一张图,边上的权值表示长度.现在又有一些边,只能从其中选一条加入原图,使起点->终点的距离最小. 当加上一条边a->b,如果这条边更新了最短路,那么起点st- ...
- uva 11374 最短路+记录路径 dijkstra最短路模板
UVA - 11374 Airport Express Time Limit:1000MS Memory Limit:Unknown 64bit IO Format:%lld & %l ...
- 训练指南 UVA - 11374(最短路Dijkstra + 记录路径 + 模板)
layout: post title: 训练指南 UVA - 11374(最短路Dijkstra + 记录路径 + 模板) author: "luowentaoaa" catalo ...
随机推荐
- jQuery实现复选框 全选、反选、全不选
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <hea ...
- linux rm指定的文件
如何删除一个目录下的除了想要的文件之外的所有文件 rm `ls | grep -v "aa"` Linux下 报错“命令参数列表过长”,在用mv命令一次移动3万多个文件时失败了,原 ...
- flam3 ubuntu 依赖文件
http://packages.ubuntu.com/zh-cn/source/precise/flam3 » Ubuntu » 软件包 » precise (12.04LTS) » 源代码 » x1 ...
- ruby on rails 数据库操作
(1)增加列的操作 rails generate migration add_password_digest_to_students password_digest:string bundle exe ...
- C++必知必会
C++ Common knowledge Essential Intermediate Programming C++必知必会 [美] StephenC.Dewhurst 著 荣耀 译 人民邮电出 ...
- 机器学习与R语言:kNN
#---------------------------------------- # 功能描述:演示kNN建模过程 # 数据集:威斯康星乳腺癌诊断 # #---------------------- ...
- 负载均衡技术在CDN中发挥着重要作用
转载地址:http://www.qicaispace.com/gonggao/server/page01/info07.asp CDN是一个经策略性部署的整体系统,能够帮助用户解决分布式存储.负载均衡 ...
- 学Git,用Git ②
之前介绍了git的最核心功能游戏存档式的本地版本管理.这会我们介绍git剩下的两个核心功能:分支和远程仓库. 1.Git游戏存档进化版--Git分支 git分支的思想很有意思,git允许我们可以随时从 ...
- hadoop2对应的eclipse插件使用
1. eclipse插件安装步骤: a).把插件复制到eclipse安装目录plugins文件夹下 b).打开eclipse的Window---Preference---Hadoop M/R---指向 ...
- zsh + oh-my-zsh 默认shell
项目地址 zsh -----> http://www.zsh.orgoh-my-zsh ----> http://ohmyz.sh The last shell you’ll ever n ...