1003 Emergency (25 分)

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 Specification:

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 C1- 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 , c1 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 C1.

Output Specification:

For each test case, print in one line two numbers: the number of different shortest paths between C1 and C1 , 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,出发城市,目的城市

第二行输入为:各个城市医疗队的数量

最后m行每行为:c1 到c1以及权重

求单元最短路径首先应该想到的是Dijkstra算法,单元最短路径不止一条,并且要记录出发城市到目的城市的医疗队数量,可以采用vector进行存储,每个节点的长度代表单元路径条数,值代表医疗队数量。

**城市医疗队分布图**
![](https://img2018.cnblogs.com/blog/1648242/201904/1648242-20190409150812020-819659854.png)
**vector存储结构**
```c++
// 1003_Emergency.cpp : Defines the entry point for the console application.
//

include "stdafx.h"

include

include <string.h>

include

define MaxSize 500

using namespace std;

int Graph[MaxSize][MaxSize]; // 图数组

int vis[MaxSize]={0},dis[MaxSize];

int curNum[MaxSize]={0};

int n,m,cur,des; // n 城市个数,m 为路径,cur 为目前所在城市,des 为目标城市

const int INF=0x7f;

vector vec[MaxSize];

// 输入数据

void Input(){

int i,x,y,z;

cin>>n>>m>>cur>>des;

memset(Graph,-1,sizeof(Graph));

for(i=0;i<n;i++)

dis[i]=MaxSize;

// 每个城市的救援队数量

for(i=0;i<n;i++)

cin>>curNum[i];

// 输入图

for(i=0;i<m;i++){

cin>>x>>y>>z;

Graph[x][y]=z;

Graph[y][x]=z;

}

}

void push(int target,int dataid)

{

for(int i=0;i<vec[dataid].size();i++)

// 当前城市医疗队数量+前一节点医疗队数量

vec[target].push_back(vec[dataid][i]+curNum[target]);

}

void Dijkstra(int cur,int des){

int i,Min;

int cen=cur;

vis[cur]=1; // 已访问

vec[cur].push_back(curNum[cur]);

dis[cur]=0;

while(true){

// 找到相邻节点 更新距离

for(i=0;i<n;i++){

if(vis[i]0&&Graph[cen][i]!=-1){

if(Graph[cen][i]+dis[cen]<dis[i]){

dis[i]=Graph[cen][i]+dis[cen];

vec[i].clear(); // 清除当前城市数据节点

push(i,cen);

}else if(Graph[cen][i]+dis[cen]dis[i]){

push(i,cen);

}

}

}

// 找到下一节点

Min=INF;

for(i=0;i<n;i++){

if(vis[i]0&&dis[i]<Min){

Min=dis[i];

cen=i;

}

}

vis[cen]=1;

if(cendes)

break;

}

}

int main(int argc, char* argv[])

{

Input();

Dijkstra(cur,des);

vector desVec=vec[des];

cout<<desVec.size()<<' ';

// 找单元最短路径最大医疗队数量

int MaxValue=desVec[0];

for(int i=1;i<desVec.size();i++){

if(MaxValue<desVec[i]){

MaxValue=desVec[i];

}

}

cout<<MaxValue << endl;

return 0;

}

**<center>2020考研打卡第一天,你可知道星辰之变,骄阳岂是终点?千万不要小看一个人的决心。加油!!!</center>**
**<center>人生为棋,我愿为卒,行动虽慢,可谁也没见我后退一步。</center>**

PAT-1003 Emergency(Dijkstra)的更多相关文章

  1. 1003 Emergency (25 分)

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

  2. 迪杰斯特拉(dijkstra)算法的简要理解和c语言实现(源码)

    迪杰斯特拉(dijkstra)算法:求最短路径的算法,数据结构课程中学习的内容. 1 . 理解 算法思想::设G=(V,E)是一个带权有向图,把图中顶点集合V分成两组,第一组为已求出最短路径的顶点集合 ...

  3. 最短路径之迪杰斯特拉(Dijkstra)算法

    迪杰斯特拉(Dijkstra)算法主要是针对没有负值的有向图,求解其中的单一起点到其他顶点的最短路径算法.本文主要总结迪杰斯特拉(Dijkstra)算法的原理和算法流程,最后通过程序实现在一个带权值的 ...

  4. 理解最短路径——迪杰斯特拉(dijkstra)算法

    原址地址:http://ibupu.link/?id=29 1.       迪杰斯特拉算法简介 迪杰斯特拉(dijkstra)算法是典型的用来解决最短路径的算法,也是很多教程中的范例,由荷兰计算机科 ...

  5. PAT 1003 Emergency

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

  6. 图论——迪杰斯特拉算法(Dijkstra)实现,leetcode

    迪杰斯特拉算法(Dijkstra):求一点到另外一点的最短距离 两种实现方法: 邻接矩阵,时间复杂度O(n^2) 邻接表+优先队列,时间复杂度O(mlogn)(适用于稀疏图) (n:图的节点数,m:图 ...

  7. 算法-迪杰斯特拉算法(dijkstra)-最短路径

    迪杰斯特拉算法(dijkstra)-最短路径 简介: 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中 ...

  8. 数据结构与算法——迪杰斯特拉(Dijkstra)算法

    tip:这个算法真的很难讲解,有些地方只能意会了,多思考多看几遍还是可以弄懂的. 应用场景-最短路径问题 战争时期,胜利乡有 7 个村庄 (A, B, C, D, E, F, G) ,现在有六个邮差, ...

  9. PAT (Advanced Level) Practise 1003 Emergency(SPFA+DFS)

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

随机推荐

  1. 【转】Java学习---解析Java Servlet工作过程

    [原文]https://www.toutiao.com/i6594316694657696264/ 解析Java Servlet工作过程 Servlet简介 Servlet是sun公司提供的一门用于开 ...

  2. /etc/sudoers文件的分析以及sudo的高级用法

    高级用法总结: sudo命令是普通用户的提权操作指令.在权限控制中,我们可以使用/etc/sudoers文件中来进行设置.基本的用法比较熟悉.比如设置一个普通用户可拥有root用户的运行权限,那么设置 ...

  3. ActiveX多线程回调JavaScript

    http://www.cnblogs.com/zdxster/archive/2011/01/27/1945872.html

  4. js面对对象编程(二):属性和闭包

    上篇博客中解说了一些js对象的基本概念和使用方法.这篇博客解说一下js属性方面的:公有属性.私有属性,特权方法. 假设学过java.公有属性.私有属性,特权方法(即能够訪问和设置私有属性的方法)一定非 ...

  5. Mysql双主 keepalived+lvs实现mysql高可用性

    MySQL复制 能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.但是MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现 ...

  6. Postman-自动化传参

    一,自动化传参 在实现接口自动测试的时候,会经常遇到接口参数依赖的问题,例如调取登录接口的时候,需要先获取登录的key值,而每次请求返回的key值又是不一样的,那么这种情况下,要实现接口的自动化,就要 ...

  7. 错误 ORA-01102: cannot mount database in EXCLUSIVE mode 的处理方法

    今天启动数据库时报错了! SQL> startup mount ORACLE instance started. Total System Global Area  608174080 byte ...

  8. 理解C#的Lock语法意义

    一. 为什么要lock,lock了什么? 当我们使用线程的时候,效率最高的方式当然是异步,即各个线程同时运行,其间不相互依赖和等待.但当不同的线程都需要访问某个资源的时候,就需要同步机制了,也就是说当 ...

  9. WorldWind源码剖析系列:视景体类Frustum

    PluginSDK中的视景体类Frustum是三维计算机图形学中的概念,主要用来描述透视投影的过程.三维计算机图形学中关于三维物体的渲染,Direct3D和OpenGL都是先通过对现实世界中的场景先进 ...

  10. OpenCV——HOG特征检测

    API: HOGDescriptor(Size _winSize, ---:窗口大小,即检测的范围大小,前面的64*128 Size _blockSize,--- 前面的2*2的cell,即cell的 ...