链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805073643683840


题目:

作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图。在地图上显示有多个分散的城市和一些连接城市的快速道路。每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上。当其他城市有紧急求助电话给你的时候,你的任务是带领你的救援队尽快赶往事发地,同时,一路上召集尽可能多的救援队。

输入格式:

输入第一行给出4个正整数N、M、S、D,其中N(2)是城市的个数,顺便假设城市的编号为0 ~ (;M是快速道路的条数;S是出发地的城市编号;D是目的地的城市编号。

第二行给出N个正整数,其中第i个数是第i个城市的救援队的数目,数字间以空格分隔。随后的M行中,每行给出一条快速道路的信息,分别是:城市1、城市2、快速道路的长度,中间用空格分开,数字均为整数且不超过500。输入保证救援可行且最优解唯一。

输出格式:

第一行输出最短路径的条数和能够召集的最多的救援队数量。第二行输出从S到D的路径中经过的城市编号。数字间以空格分隔,输出结尾不能有多余空格。

输入样例:

4 5 0 3
20 30 40 10
0 1 1
1 3 2
0 3 3
0 2 2
2 3 2

输出样例:

2 60
0 1 3

题意:
有n个城市 m条路径 起点为s 终点为d 每个城市拥有的价值为num[i] 求出一条最短路 使得路径最短并且尽可能价值最大
题目保证最佳选择存在并唯一
要求输出为最短路径条数和最大的价值和 路径打印 思路:
题目描述有一个坑点 即输出的最短路径条数不是指最后所求的最佳路径上有几条路 而是抛开价值的条件 单纯求距离最短的最短路径有几条
采用dijkstra的思路 用邻接矩阵来存图 但是有不足的地方 即邻接矩阵无法处理最短路计数中的重边 但是数据中应该没有重边数据 之后打算转用邻接表再写一遍
在寻边操作中 只要按照距离来找就可以 因为后来都会更新一遍
在松弛操作时 采用了两个关键词 主关键词为距离dis 记录当前总距离 副关键词为tot 记录当前总价值 如果是用距离来更新的 路径记录dis1[j]=dis1[tmp]
如果路径相等 不管是否用价值更新 路径记录均为dis1[j]+=dis1[tmp] 当前节点加上到tmp节点的最短路径数量
在路径输出部分 存储顺序为倒序 输出时要从后往前

代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <string>
#include <cstring>
#include <algorithm> using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int inf=0x3f3f3f3f;
const int maxn=;
int n,m,s,d,x,y,w;
int mp[maxn][maxn],dis[maxn],dis1[maxn],tot[maxn],vis[maxn],num[maxn],ans[maxn],path[maxn]; void dijkstra(int st){
for(int i=;i<n;i++){
dis[i]=inf;
vis[i]=;
dis1[i]=;
}
dis[st]=;tot[st]=num[st];
vis[st]=;dis1[st]=;
for(int i=;i<n;i++){
int tmp,minn=inf,maxx=-;
for(int j=;j<n;j++){
if(!vis[j] && (dis[j]<minn)){
minn=dis[j];
tmp=j;
} }
cout<<tmp<<" "<<minn<<" "<<dis1[tmp]<<endl;
if(minn==inf) break;vis[tmp]=;
for(int j=;j<n;j++){
if(!vis[j] && dis[tmp]+mp[tmp][j]<dis[j]){
dis1[j]=dis1[tmp];
dis[j]=dis[tmp]+mp[tmp][j];
tot[j]=tot[tmp]+num[j];
path[j]=tmp;
}
else if(!vis[j] && dis[tmp]+mp[tmp][j]==dis[j]){
if(tot[tmp]+num[j]>tot[j]){
tot[j]=tot[tmp]+num[j];
path[j]=tmp;
}
dis1[j]+=dis1[tmp];//加上到tmp节点的最短路径数量
}
}
}
} int main(){
scanf("%d%d%d%d",&n,&m,&s,&d);
for(int i=;i<n;i++){
scanf("%d",&num[i]);
}
for(int i=;i<n;i++)
for(int j=;j<n;j++)
mp[i][j]=inf;
for(int i=;i<=m;i++){
scanf("%d%d%d",&x,&y,&w);
w=min(mp[x][y],w);
mp[x][y]=mp[y][x]=w;
}
dijkstra(s);
printf("%d %d\n",dis1[d],tot[d]);
int cnt=;
for(int i=d;i>=;i=path[i]){
ans[++cnt]=i;
if(i==s) break;
}
for(int i=cnt;i>;i--){
printf("%d ",ans[i]);
}
printf("%d\n",ans[]);
return ;
}

 

L2-001 紧急救援 (25 分) (最短路+路径打印)的更多相关文章

  1. 5-5 城市间紧急救援 (25分)【最短路spfa】

    5-5 城市间紧急救援   (25分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速 ...

  2. PTA数据结构与算法题目集(中文) 7-35 城市间紧急救援 (25 分)

    PTA数据结构与算法题目集(中文)  7-35 城市间紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市 ...

  3. 天梯L2-001. 紧急救援(25分)

    L2-001. 紧急救援 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国 ...

  4. PAT-1003 Emergency (25 分) 最短路最大点权+求相同cost最短路的数量

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

  5. BFS(最短路+路径打印) POJ 3984 迷宫问题

    题目传送门 /* BFS:额,这题的数据范围太小了.但是重点是最短路的求法和输出路径的写法. dir数组记录是当前点的上一个点是从哪个方向过来的,搜索+,那么回溯- */ /************* ...

  6. L2-001 紧急救援 (25 分)

    L2-001 紧急救援 (25 分)   作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快 ...

  7. 天梯 L2 紧急救援 (dijkstra变形+记录路径)

    L2-001 紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速道 ...

  8. 城市间紧急救援(25 分)(dijstra变形)

    城市间紧急救援(25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速道路长度都标 ...

  9. PTA 05-树7 堆中的路径 (25分)

    题目地址 https://pta.patest.cn/pta/test/15/exam/4/question/713 5-5 堆中的路径   (25分) 将一系列给定数字插入一个初始为空的小顶堆H[] ...

随机推荐

  1. vue 2.0 + ElementUI构建树形表格

    解决: 本来想在网上博客找一找解决方法,奈何百度到的结果都不尽人意,思维逻辑不清,步骤复杂,代码混乱,找了半天也没找到一个满意的,所以干脆就自己动手写一个 思路: table需要的数据是array,所 ...

  2. SpringCloud(6)分布式配置中心Spring Cloud Config

    1.Spring Cloud Config 简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件.在Spring Cloud中,有分布式配置中心组 ...

  3. (poj 2502) Subway 最短路

    题目链接: 题意:在一个城市里有许多地铁,现在你知道每条地铁的起点  终点与停站点的坐标,知道我们的起始坐标与终点坐标,问加上走路最快到达终点的时间是多少? 方法:求出任意两点的车速时间与步行时间,再 ...

  4. PS制作漂亮紫色霓虹灯光文字

    一.新建画布,大小1500 * 950像素,分辨率为300,置入墙壁图像,大小适合. 二.调整图层的色阶,色相/饱和度. 三.新建文字图层,颜色为#a33e88,大小为103,字体为Beon Medi ...

  5. 家庭记账本小程序之查(java web基础版六)

    实现查询消费账单 1.main_left.jsp中该部分,调用search.jsp 2.search.jsp,提交到Servlet中的search方法 <%@ page language=&qu ...

  6. Linux centos7.5操作系统的安装

    安装centos7.5 1.1 新建虚拟机 1.2 选择客户机系统和版本 1.3 更改虚拟机名称和创建地址.   1.4 选择网络类型 1.5 自定义硬件,选择添加centos7.5镜像 1.6 开机 ...

  7. Shell命令-文件及内容处理之iconv、dos2unix

    文件及内容处理 - iconv.dos2unix 1. iconv:转换文件的编码格式 iconv命令的功能说明 iconv 命令是 linux 下用于文件转编码的常用命令,对于同时使用 window ...

  8. Flask--路由, 配置, 蓝图

    一 . 双重装饰器重名的解决办法 # 我们都知道flask中的@app.route就是一层装饰器, 当我们需要在给视图函数加装饰器的时候就两层装饰器,这里介绍一下加装饰器的先后顺序,以及遇到的问题. ...

  9. 好用的UI设计工具

    51yuansu  好用的在线画UI图工具    51yuansu.com processon.com processon在线画图工具,程序流程图及UI设计原型图,脑图等 draw.io的PC版画图工 ...

  10. git 学习(1) ----- git 本地仓库操作

    最近在项目中使用git了,在实战中才知道,以前学习的git 知识只是皮毛,需要重新系统的学一下,读了一本叫  Learn Git in a Month of Lunches 的书籍,这本书通俗易懂,使 ...