As an emergency rescue team leader of a city, you are given a special map of your country. The map shows several scattered cities connected by some roads. Amount of rescue teams in each city and the length of each road between any pair of cities are marked on the map. When there is an emergency call to you from some other city, your job is to lead your men to the place as quickly as possible, and at the mean time, call up as many hands on the way as possible.

Input

Each input file contains one test case. For each test case, the first line contains 4 positive integers: N (<= 500) – the number of cities (and the cities are numbered from 0 to N-1), M – the number of roads, C1 and C2 – the cities that you are currently in and that you must save, respectively. The next line contains N integers, where the i-th integer is the number of rescue teams in the i-th city. Then M lines follow, each describes a road with three integers c1, c2 and L, which are the pair of cities connected by a road and the length of that road, respectively. It is guaranteed that there exists at least one path from C1 to C2.

Output

For each test case, print in one line two numbers: the number of diferent shortest paths between C1 and C2, and the maximum amount of rescue teams you can possibly gather. All the numbers in a line must be separated by exactly one space, and there is no extra space allowed at the end of a line.

Sample Input

5 6 0 2
1 2 1 5 3
0 1 1
0 2 2
0 3 1
1 2 1
2 4 1
3 4 1

Sample Output

2 4

题目意思:有n个城市m条路相连,每个城市都有一些救援队,给定起点城市和C1和终点城市C2,求从起点到终点最短路径的条数以及最短路径上能够调动来的救援队的数目。

解题思路:和一般求最短路的题目不同,这里所求的是最短路的数目和最短路上点的权值和(将城市看做点,那么每个城市中救援队的数目就可以看成点的权值)。其实既然是最短路,无非就是那几个算法,这里我们来考虑最短路数目不唯一的原因,从起点到终点的边的权值和是一样的,但经过的点是不一样的,这可以用Dijkstra来对每一个点逐步贪心,判断是否需要纳入到最短路结点的集合中。这里用dis[i]表示从起点C1到i点最短路的路径长度,用num[i]表示从起点到i点最短路的个数,用w[i]表示从起点到i点救援队的数目之和。当判定dis[u] + e[u][v] < dis[v]的时候,也就是说新纳入的u点可以减短到v的路径长度,是符合要求的,不仅仅要更新dis[v],还要更新num[v] = num[u], w[v] = weight[v] + w[u]; 如果dis[u] + e[u][v] ==dis[v],也就是说新纳入的u点,经过u到达v的路径长度和不经过u到v的路径长度一致,这就产生了两条最短路了,这时候要更新num[v] += num[u],⽽且判断⼀下是否权重w[v]更⼩,如果更⼩了就更新w[v] = weight[v] + w[u];

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
const int inf= ;
using namespace std;
int n,m,c1,c2;
int e[][];
int w[];//救援队数目之和
int dis[];//从起点到i点最短路径的长度
int num[];//最短路径的条数
int weight[];//第i个城市救援队数目,点权
bool vis[];
int main()
{
int a,b,c,i,j,mins,u,v;
scanf("%d%d%d%d",&n,&m,&c1,&c2);
for(i=; i<n; i++)
{
scanf("%d",&weight[i]);
}
fill(e[], e[] + * , inf);
fill(dis, dis + , inf);
for(i=; i<m; i++)//建图
{
scanf("%d%d%d",&a,&b,&c);
e[a][b]=e[b][a]=c;
}
dis[c1]=;
w[c1]=weight[c1];
num[c1]=;//至少会有一条最短路
for(i=; i<n; i++)//遍历所有的点
{
u=-;//因为是正权通路,这里设置为-1
mins=inf;
for(j=; j<n; j++)//找到距离已纳入点集合中的最近点
{
if(vis[j]==false&&dis[j]<mins)
{
u=j;
mins=dis[j];
}
//printf("%d\n",mins);
} if(u==-)
{
break;
}
vis[u]=true;//标记该点以纳入S集
for(v=; v<n; v++)//更新刚纳入的u点与其他尚未纳入点之间的距离
{
if(vis[v]==false&&e[u][v]!=inf)
{
if(dis[u]+e[u][v]<dis[v])//Dijkstra
{
dis[v]=dis[u]+e[u][v];//更新边权
num[v]=num[u];//最短路条数不会变
w[v]=w[u]+weight[v];//最短路沿路的救援队数
}
else if(dis[u]+e[u][v]==dis[v])//出现边权相等
{
num[v]=num[v]+num[u];//产生了两条分路
if(w[u]+weight[v]>w[v])//取点权最大的表示为到v的救援队数目
{
w[v]=w[u]+weight[v];
}
}
}
}
}
printf("%d %d",num[c2],w[c2]);
return ;
}

PAT 1003 Emergency 最短路的更多相关文章

  1. PAT 1003. Emergency (25)

    1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...

  2. PAT 1003. Emergency (25) dij+增加点权数组和最短路径个数数组

    1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...

  3. PAT 1003 Emergency

    1003 Emergency (25 分)   As an emergency rescue team leader of a city, you are given a special map of ...

  4. PAT 1003 Emergency[图论]

    1003 Emergency (25)(25 分) As an emergency rescue team leader of a city, you are given a special map ...

  5. PAT 1003. Emergency 单源最短路

    思路:定义表示到达i的最短路径数量,表示到达i的最短径,表示最短路径到达i的最多人数,表示从i到j的距离, 表示i点的人数.每次从u去更新某个节点v的时候,考虑两种情况: 1.,说明到达v新的最短路径 ...

  6. PAT 1003 Emergency (25分)

    As an emergency rescue team leader of a city, you are given a special map of your country. The map s ...

  7. 图论 - PAT甲级 1003 Emergency C++

    PAT甲级 1003 Emergency C++ As an emergency rescue team leader of a city, you are given a special map o ...

  8. PAT甲级1003. Emergency

    PAT甲级1003. Emergency 题意: 作为一个城市的紧急救援队长,你将得到一个你所在国家的特别地图.该地图显示了几条分散的城市,连接着一些道路.每个城市的救援队数量和任何一对城市之间的每条 ...

  9. PAT 甲级 1003. Emergency (25)

    1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...

随机推荐

  1. django甜甜的弹窗

    GitHub中甜甜的弹窗地址: https://github.com/lipis/bootstrap-sweetalert 直接简单粗暴选择右下角的download,下载到本地一份文件 小猿取经中的相 ...

  2. jfinal shiro共享

    和上一篇tomcat sexxion共享一样,用的也是redis 代码: package com.test.shiro; import com.jfinal.log.Log; import com.j ...

  3. 面试 3-5年Java开发后的感受

    在上周,我密集面试了若干位Java后端的候选人,工作经验在3到5年间.我的标准其实不复杂:第一能干活,第二Java基础要好,第三最好熟悉些分布式框架,我相信其它公司招初级开发时,应该也照着这个标准来面 ...

  4. LImax服务器框架学习--安装、使用ant工具、生成limax相关代码

    一.安装ant ant 是一个将软件编译.测试.部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发.在实际软件开发中,有很多地方可以用到ant. 首先现在一个ant安装压缩包, ...

  5. Power BI 的数据源及数据刷新

    Power BI 目前可以连接超过100种数据源,包含常见的各种数据库,文件,数据仓库,云等等. 不同的数据源支持不同的连接方式,通常来讲,Power BI 支持两种数据连接方式: 导入(import ...

  6. Python面向对象-多重继承之MixIN

    以Animal类为例,假设要实现以下4种动物: Dog(狗).Bat(蝙蝠).Parrot(鹦鹉)和Ostrich(鸵鸟) 如果按照哺乳类和鸟类来区分的话,可以这样设计: Animal: |--Mam ...

  7. netcore在CentOS7 下使用处理图片的问题

    请看代码,当你在centos下要把图片转为Base64的时候 MemoryStream ms = new MemoryStream(); try { Bitmap bmp = new Bitmap(f ...

  8. Redis学习(二)Redis的安装

    Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases. Redis 支持 32 位和 64 位.这个需要根据你系统平台的实际情况选择 ...

  9. C# sync/async 同步/异步

    同步方法 Console.WriteLine($")} {DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")}******* ...

  10. springboot(二):bootstrap和application有什么区别?

    “SpringBoot专注于快速方便的开发单个个体微服务. SpringCloud是关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务整合并管理起来, 为各个服务之间提供 ...