PAT 1003 Emergency 最短路
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 最短路的更多相关文章
- PAT 1003. Emergency (25)
1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...
- PAT 1003. Emergency (25) dij+增加点权数组和最短路径个数数组
1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...
- PAT 1003 Emergency
1003 Emergency (25 分) As an emergency rescue team leader of a city, you are given a special map of ...
- PAT 1003 Emergency[图论]
1003 Emergency (25)(25 分) As an emergency rescue team leader of a city, you are given a special map ...
- PAT 1003. Emergency 单源最短路
思路:定义表示到达i的最短路径数量,表示到达i的最短径,表示最短路径到达i的最多人数,表示从i到j的距离, 表示i点的人数.每次从u去更新某个节点v的时候,考虑两种情况: 1.,说明到达v新的最短路径 ...
- 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 ...
- 图论 - PAT甲级 1003 Emergency C++
PAT甲级 1003 Emergency C++ As an emergency rescue team leader of a city, you are given a special map o ...
- PAT甲级1003. Emergency
PAT甲级1003. Emergency 题意: 作为一个城市的紧急救援队长,你将得到一个你所在国家的特别地图.该地图显示了几条分散的城市,连接着一些道路.每个城市的救援队数量和任何一对城市之间的每条 ...
- PAT 甲级 1003. Emergency (25)
1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...
随机推荐
- mybatis源码学习(四)--springboot整合mybatis原理
我们接下来说:springboot是如何和mybatis进行整合的 1.首先,springboot中使用mybatis需要用到mybatis-spring-boot-start,可以理解为mybati ...
- Python代码编写规范,你真的会吗?
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:yangjiajia123456 最近两年的工作都是和运维相关,有时 ...
- Python之利用Whoosh搭建轻量级搜索
本文将简单介绍Python中的一个轻量级搜索工具Whoosh,并给出相应的使用示例代码. Whoosh简介 Whoosh由Matt Chaput创建,它一开始是一个为Houdini 3D动画软 ...
- Cannot read property 'createElement' of undefined
场景: 架构:React+TS+DVA 具体场景: 在将之前后缀为jsx的组件转化为tsx后缀的组件时,抛出Cannot read property 'createElement' of unde ...
- 消费者驱动的契约Consumer drivern Contract
消费者驱动的契约Consumer Driven Contracts (CDC) A contract between a consuming service and a providing servi ...
- MESSAGE_TYPE_X dump in RSM_DATASTATE_CHECK -6-
DTP抽数时系统Dump 参考sapnote:2398760 - MESSAGE_TYPE_X dump in RSM_DATASTATE_CHECK -1- to -12- RSM_DATASTAT ...
- windows 安装xps查看器; windows 10 安装 xps viewer
最近发现windows 默认是没有xps 查看器的,需要自己手动添加: 安装完成后,即可使用: 参考链接:https://www.windowscentral.com/how-get-xps-view ...
- WSL2(预览版)体验笔记
WSL2安装 WSL2在今年5月份Microsoft Build大会上发布了,但至今Windows10一直没收到更新推送,我想这么久过去就算没进入正式,至少也到了RC版了吧,于是开始折腾准备体验一把. ...
- Xposed的新打开方式--Xpatch工作流程分析
1. Xpatch概述 Xpatch是一款利用重打包的方式,使得被处理的Apk启动时自动加载Xposed模块,来实现应用内Hook的工具. 项目地址:https://github.com/WindyS ...
- C# -- 模拟扑克牌发牌
C# -- 模拟扑克牌发牌 1. User 类: 玩家 public class User { private List<PaperCard> listCard = new List&l ...