Description

贝西有两个又香又脆的红苹果要送给她的两个朋友。当然她可以走的C(1<=C<=200000)条“牛路”都被包含在一种常用的图中,包含了P(1<=P<=100000)个牧场,分别被标为1..P。没有“牛路”会从一个牧场又走回它自己。“牛路”是双向的,每条牛路都会被标上一个距离。最重要的是,每个牧场都可以通向另一个牧场。每条牛路都连接着两个不同的牧场P1_i和P2_i(1<=P1_i,p2_i<=P),距离为D_i。所有“牛路”的距离之和不大于2000000000。

现在,贝西要从牧场PB开始给PA_1和PA_2牧场各送一个苹果(PA_1和PA_2顺序可以调换),那么最短的距离是多少呢?当然,PB、PA_1和PA_2各不相同。

Input

第一行,5个整数,\(C,P,PB,PA1,PA2\)(含义如题所述)

接下来\(C\)行,每行三个整数\(x,y,z\)描述一条无向边。

Output

一个整数,代表最小距离.

难得遇到一个这么裸的最短路题。

貌似\(Spfa\)会被\(Hack\)?

直接写\(Dijkstra\)。

分别以\(PA1\),\(PA2\)为起点跑\(Dijkstra\)。

每次对于到达其他两个点的距离取\(min\)即可。

代码

#include<cstdio>
#include<algorithm>
#include<queue>
#include<iostream>
#define R register using namespace std; const int gz=200008; inline void in(int &x)
{
int f=1;x=0;char s=getchar();
while(!isdigit(s)){if(s=='-')f=-1;s=getchar();}
while(isdigit(s)){x=x*10+s-'0';s=getchar();}
x*=f;
} int m,n,s,a,b,ans=214748364;
int head[gz],tot,dis[gz];
bool vis[gz]; struct hop
{
int u,d;
bool operator <(const hop&a)const
{
return d>a.d;
}
}; struct cod{int u,v,w;}edge[gz<<2]; inline void add(R int x,R int y,R int z)
{
edge[++tot].u=head[x];
edge[tot].v=y;
edge[tot].w=z;
head[x]=tot;
} inline void dijkstra(R int s)
{
for(R int i=1;i<=n;i++)dis[i]=214748364,vis[i]=false;
priority_queue<hop>q;
q.push((hop){s,dis[s]=0});
while(!q.empty())
{
R int u=q.top().u;q.pop();
if(vis[u])continue;
vis[u]=true;
for(R int i=head[u];i;i=edge[i].u)
{
if(dis[edge[i].v]>dis[u]+edge[i].w)
{
dis[edge[i].v]=dis[u]+edge[i].w;
q.push((hop){edge[i].v,dis[edge[i].v]});
}
}
}
} int main()
{
in(m),in(n),in(s),in(a),in(b);
for(R int i=1,x,y,z;i<=m;i++)
{
in(x),in(y),in(z);
add(x,y,z);add(y,x,z);
} dijkstra(a);
ans=min(ans,dis[b]+dis[s]);
dijkstra(b);
ans=min(ans,dis[a]+dis[s]); printf("%d",ans);
}

最新文章

  1. jquery的ajax可以传入的三种参数类型
  2. A Simple C++ Template Class that Matches a String to a Wildcard Pattern
  3. Oracle 查询系统所有用户信息
  4. Linux netmask
  5. &lt;路径算法&gt;哈密顿路径变种问题(2016华为软件精英挑战赛初赛)
  6. JavaScript 内部对象
  7. asp.net get server control id from javascript
  8. in_array 判断问题的疑惑解决。
  9. JavaScript 高级程序设计(第3版)笔记——chapter5:引用类型
  10. Natas Wargame Level25 Writeup(头部注入+POST/GET注入)
  11. centos 7 安装VCL播放器
  12. net core体系-web应用程序-4asp.net core2.0 项目实战(1)-12基于cookie登录授权认证并实现前台会员、后台管理员同时登录
  13. [转]Ble蓝牙的使用手册
  14. ARM核心板_迅为4418核心板_高稳定超轻薄_研发超灵感
  15. PHPCMS V9完全开发介绍
  16. 微信小程序——豆瓣电影——(1):基础入门
  17. Xgboost理解
  18. JAVA反射会降低你的程序性能吗?
  19. 1009 产生数 2002年NOIP全国联赛普及组
  20. 【JQuery】数据

热门文章

  1. Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition) C (用map 超时)
  2. IOI1998 Polygon [区间dp]
  3. Codeforces Global Round 1 (A-E题解)
  4. codeforces 1060 D
  5. java过滤器和监听器详解
  6. mysql_存储过程和函数
  7. Linux Uptime 命令,让你知道你的系统运行了多久
  8. 图论:Gale-Shapley算法
  9. c++对拍实现
  10. java深入解析