问题描述

洛谷(有翻译)


吐槽

一道坑题。


如何对待商务票

因为商务票只有一张,所以在\(k\)条边中只有一条边会被选中,很显然,最后这条边会被枚举。


如何选择使用商务票的边

假设我们正在枚举这条边,现在的边为\((u,v)\),边权为\(w\)。

那么现在的最小代价肯定为

\[min(dist_{(s,u)_{min}}+dist_{(v,e)_{min}}+w,dist_{(s,v)_{min}}+dist_{(u,e)_{min}}+w)
\]

其中\(s\)代表起点,\(e\)代表终点,\(dist_{(a,b)}\)代表\(a\)到\(b\)的距离。

从\(dist_{(a,b)_{min}}\)中,我们可以很清楚地感受到,需要跑最短路。

强烈推荐使用\(dijkstra\)+堆优化。

如果你不确定你的最短路模板是否正确,请移步


两次最短路

经过分析,我们知道要跑最短路,但是由于有两个点分别到\(s\)和\(e\)的最短距离,那么就需要以\(s\)和\(e\)分别为源,跑单源最短路径。

最短路中需要记录前驱。


总思路

先读入,注意多组测试数据。

再跑两遍最短路。

枚举\(k\)条边,对于每一条边\((u,v)\),用上面的公式和当前最优的\(ans\)比较并记录。

最后输出。(如果挂了先调这个)


细节

  • 每组测试数据的输出之间需要一个空行

  • 最后一组测试数据后不能有空行

  • 行末不能有多余的空格


彩蛋

点这里

可能有点卡


代码

#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std; #define maxn 500
#define maxm 1000
struct node{
int dis,x;
bool operator <(const node &a)const
{
return dis>a.dis;
}
};
int h_j[maxn+7],n_j[maxm*2+7],h_s[maxn+7],n_s[maxm*2+7],u_j[maxm*2+7],v_j[maxm*2+7],w_j[maxm*2+7],tot_j,u_s[maxm*2+7],v_s[maxm*2+7],w_s[maxm*2+7],tot_s;
int s,e,n,m,k,x,y,z,p[maxn+7],dis1[maxn+7],dis2[maxn+7],qi1[maxn+7],qi2[maxn+7],ans=0x7fffffff,ansi,ansj;
bool used1[maxn+7],used2[maxn+7];
int u[maxm+7],v[maxm+7],w[maxm+7],stac[maxn+7],cas,xx,top;
void add_j()
{
u_j[++tot_j]=x,v_j[tot_j]=y,w_j[tot_j]=z;
n_j[tot_j]=h_j[x],h_j[x]=tot_j;
u_j[++tot_j]=y,v_j[tot_j]=x,w_j[tot_j]=z;
n_j[tot_j]=h_j[y],h_j[y]=tot_j;
}
void clear()
{
memset(h_j,0,sizeof(h_j));
memset(n_j,0,sizeof(n_j));
memset(used1,0,sizeof(used1));
memset(used2,0,sizeof(used2));
tot_j=0;
memset(qi1,0,sizeof(qi1));
memset(qi2,0,sizeof(qi2));
ans=0x7fffffff;
}
int mian()
{
while((~scanf("%d%d%d",&n,&s,&e))&&n&&s&&e)
{
if(cas++) printf(" ");
clear();
scanf("%d",&m);
for(register int i=1;i<=m;i++)
{
scanf("%d%d%d",&x,&y,&z);
add_j();
}
scanf("%d",&k);
for(register int i=1;i<=k;i++)
{
scanf("%d%d%d",&x,&y,&z);
u[i]=x,v[i]=y,w[i]=z;
}
for(register int i=1;i<=n;i++) dis1[i]=dis2[i]=0x3f3f3f3f;
priority_queue<node>q1;
dis1[s]=0;
q1.push((node){0,s});
while(!q1.empty())
{
int u=q1.top().x;
q1.pop();
if(used1[u]) continue;
used1[u]=1;
for(int i=h_j[u];i;i=n_j[i])
{
int aa=v_j[i],co=w_j[i];
if(dis1[aa]>dis1[u]+co)
{
dis1[aa]=dis1[u]+co;qi1[aa]=u;
q1.push((node){dis1[aa],aa});
}
}
}
priority_queue<node>q2;
dis2[e]=0;
q2.push((node){0,e});
while(!q2.empty())
{
int u=q2.top().x;
q2.pop();
if(used2[u]) continue;
used2[u]=1;
for(int i=h_j[u];i;i=n_j[i])
{
int aa=v_j[i],co=w_j[i];
if(dis2[aa]>dis2[u]+co)
{
dis2[aa]=dis2[u]+co;qi2[aa]=u;
q2.push((node){dis2[aa],aa});
}
}
}
for(register int i=1;i<=k;i++)
{
if(dis1[u[i]]+dis2[v[i]]+w[i]<=ans)
{
ans=dis1[u[i]]+dis2[v[i]]+w[i];
ansi=u[i];
ansj=v[i];
}
if(dis1[v[i]]+dis2[u[i]]+w[i]<=ans)
{
ans=dis1[v[i]]+dis2[u[i]]+w[i];
ansi=v[i];
ansj=u[i];
}
}
xx=ansi;
top=0;
if(s==e)
{
printf("%d\nTicket Not Used\n0\n",s);
continue;
}
if(ans<=dis1[e])
{
while(xx!=s&&xx)
{
stac[++top]=xx;
xx=qi1[xx];
}
printf("%d ",s);
while(top)
{
printf("%d ",stac[top--]);
}
xx=ansj;
while(xx!=e&&xx)
{
stac[++top]=xx;
xx=qi2[xx];
}
int fuck=1;
while(fuck<=top)
{
printf("%d ",stac[fuck++]);
}
printf("%d\n",e);
printf("%d\n%d\n",ansi,ans);
}
else
{
int xx=qi1[e];
while(xx!=s&&xx)
{
stac[++top]=xx;
xx=qi1[xx];
}
printf("%d ",s);
while(top)
{
printf("%d ",stac[top--]);
}
printf("%d\nTicke Not Used\n%d\n",e,dis1[e]);
}
}
}

UVA11374 Airport Express 正反两次最短路的更多相关文章

  1. UVA-11374 Airport Express (dijkstra+枚举)

    题目大意:n个点,m条无向边,边权值为正,有k条特殊无向边,起止点和权值已知,求从起点到终点的边权值最小的路径,特殊边最多只能走一条. 题目分析:用两次dijkstra求出起点到任何一个点的最小权值, ...

  2. Uva11374 Airport Express

    最短路问题. 从起点和终点开始各跑一次dijkstra,可以得到起点.终点到任意点的距离.枚举使用的商业线路,找最优解. 破题卡输出,记录前驱和输出什么的仿佛比算法本身还麻烦. /*by Silver ...

  3. poj 3268 Silver Cow Party(最短路,正反两次,这个模版好)

    题目 Dijkstra,正反两次最短路,求两次和最大的. #define _CRT_SECURE_NO_WARNINGS //这是找出最短路加最短路中最长的来回程 //也就是正反两次最短路相加找最大的 ...

  4. UVA - 11374 - Airport Express(堆优化Dijkstra)

    Problem    UVA - 11374 - Airport Express Time Limit: 1000 mSec Problem Description In a small city c ...

  5. UVA - 11374 Airport Express (Dijkstra模板+枚举)

    Description Problem D: Airport Express In a small city called Iokh, a train service, Airport-Express ...

  6. BNUOJ 19792 Airport Express

    Airport Express Time Limit: 1000ms Memory Limit: 131072KB This problem will be judged on UVA. Origin ...

  7. UVA 11374 Airport Express SPFA||dijkstra

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

  8. 【uva11374】Airport Express 最短路

    题意: 在Iokh市中,机场快线是市民从市内去机场的首选交通工具.机场快线分为经济线和商业线两种,线路,速度和价钱都不同.你有一张商业线车票,可以坐一站商业线,而其他时候只能乘坐经济线.假设换乘时间忽 ...

  9. UVA 11374 Airport Express(最短路)

    最短路. 把题目抽象一下:已知一张图,边上的权值表示长度.现在又有一些边,只能从其中选一条加入原图,使起点->终点的距离最小. 当加上一条边a->b,如果这条边更新了最短路,那么起点st- ...

随机推荐

  1. request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+request.getContextPath()+"/"

    String path = request.getContextPath(); String basePath = request.getScheme()+"://"+reques ...

  2. NOIP 2016 组合数问题

    洛谷 P2822 组合数问题 洛谷传送门 JDOJ 3139: [NOIP2016]组合数问题 D2 T1 JDOJ传送门 Description 组合数Cnm表示的是从n个物品中选出m个物品的方案数 ...

  3. Ansible之roles角色

    一.roles简介 ansible自1.2版本引入的新特性,用于层次性.结构化地组织playbook.roles能够根据层次型结构自动装载变量文件.tasks以及handlers等.要使用roles只 ...

  4. Python - __name__=='__main__'是干啥的,以及python -m与python的区别

    1. __name__=='__main__'是干啥的 先看例子,准备a.py和b.py放在同一个文件夹中 vi a.py # coding: utf-8 print("i am just ...

  5. 深入理解java中的byte类型

    作者 | 进击的石头--GO! 来源 | https://www.cnblogs.com/zl181015/p/9435035.html#4432849 Java也提供了一个byte数据类型,并且是基 ...

  6. go-goroutine 和 channel

    goroutine 和 channel goroutine-看一个需求 需求:要求统计 1-9000000000 的数字中,哪些是素数? 分析思路: 1) 传统的方法,就是使用一个循环,循环的判断各个 ...

  7. java基础(7):自定义类、ArrayList集合

    1. 引用数据类型(类) 1.1 引用数据类型分类 提到引用数据类型(类),其实我们对它并不陌生,如使用过的Scanner类.Random类. 我们可以把类的类型为两种: 第一种,Java为我们提供好 ...

  8. Spring Boot 中如何定制 Banner

    本人免费整理了Java高级资料,涵盖了Java.Redis.MongoDB.MySQL.Zookeeper.Spring Cloud.Dubbo高并发分布式等教程,一共30G,需要自己领取.传送门:h ...

  9. DataGridView怎样实现添加、删除、上移、下移一行

    场景 在Winform中使用DataGridView实现添加一行.删除一行.上移一行.下移一行. 注: 博客主页: https://blog.csdn.net/badao_liumang_qizhi ...

  10. Taro聊天室|react+taro仿微信聊天App界面|taro聊天实例

    一.项目简述 taro-chatroom是基于Taro多端实例聊天项目,运用Taro+react+react-redux+taroPop+react-native等技术开发的仿微信App界面聊天室,实 ...