问题描述

洛谷(有翻译)


吐槽

一道坑题。


如何对待商务票

因为商务票只有一张,所以在\(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. testng.xml文件的配置

    ------Web自动化测试之Webdriver+TestNG--从零到熟练(系列) TestNG用来管理测试用例的是testng.xml配置文件,我们可以通过配置这个文件来达到组织测试用例,输出测试 ...

  2. WPF 精修篇 数据绑定到对象

    原文:WPF 精修篇 数据绑定到对象 数据绑定到对象 首先 我们需要一个对象 public class Preson { private string name; public string Name ...

  3. golang:exported function Script should have comment or be unexported

    当自己定义的包被外部使用时,如果不遵循一定的规范,那么会出现讨厌的绿色纹条,还会警告: 虽然不会影响运行,但是也令人讨厌,那么如何解决这个问题呢? 为结构体或者变量或者方法添加注释,并且开头必须是结构 ...

  4. Xml之Schema XSD约束{详细}

    问题: 学习Schema其他标签的定义 约束 引入的方式: 基本格式: 1构建schema: 1.1 最基本的单位元素 1.2 元素属性 1.3 simpleType 定义类型 1.4 复合结构类型 ...

  5. ros相关笔记

    catkin_make不编译某些package https://answers.ros.org/question/54181/how-to-exclude-one-package-from-the-c ...

  6. Python爬虫使用selenium爬取qq群的成员信息(全自动实现自动登陆)

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: python小爬虫 PS:如有需要Python学习资料的小伙伴可以 ...

  7. MySQL入门——MySQL数据库和SQL语言

    MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...

  8. LooseVersion()使用及.__version__版本号的获取

    我简单看了distutils库,但发现目前还用不到,感觉有些复杂.因此我简单复制了别人的介绍,如下: Distutils可以用来在Python环境中构建和安装额外的模块.新的模块可以是纯Python的 ...

  9. C#在循环中使用Random时生成的随机数相同的解决办法

    场景 在循环中使用 Random y = new Random(); 生成随机数时每次循环生成的数是一样的. ; i < ;i++ ) { Random y = new Random(); Po ...

  10. uni-app聊天室|vue+uniapp仿微信聊天实例|uniapp仿微信App界面

    一.介绍 运用UniApp+Vue+Vuex+swiper+uniPop等技术开发的仿微信原生App聊天室|仿微信聊天界面实例项目uniapp-chatroom,实现了发送图文消息.表情(gif图), ...