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

输入格式:

输入第一行给出4个正整数N、M、S、D,其中N(2<=N<=500)是城市的个数,顺便假设城市的编号为0~(N-1);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 emmmm,图论一直是弱项,简单的最短路变形一直挺模糊的无从下手,这道题值得好好学习。其实写了以后还是比较好懂的。
#include<queue>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
#define maxn 510
#define debug(a) cout << #a << " " << a << endl
//val每个城市紧急救援队的数量,re代表最短路中紧急队最多的那条路径经过的点,vis判断当前点是否走过
//total代表每个点的最短路中的紧急队最多的数量,pathnum代表当前点的最短路径的数量
//dis代表路径长度,path记录当前点的前驱
int n,m,s,d,val[maxn],mapn[maxn][maxn],re[maxn],vis[maxn];
int total[maxn],pathnum[maxn],dis[maxn],path[maxn];
void dijkstra( int v0 ) {
for( int i = ; i < n; i ++ ) {
dis[i] = 1e9;
}
vis[v0] = true;
dis[v0] = ;
total[v0] = val[v0];
pathnum[v0] = ;
for( int i = ; i < n; i ++ ) {
if( mapn[v0][i] != 1e9 && i != v0 ) {
dis[i] = mapn[v0][i];
path[i] = v0;
total[i] = val[v0] + val[i];
pathnum[i] = ;
}
}
for( int i = ; i < n - ; i ++ ) {
int minn = 1e9, mival = , u = v0;
for( int j = ; j < n; j ++ ) {
if( !vis[j] && dis[j] < minn ) {
minn = dis[j];
u = j;
}
}
vis[u] = true;
for( int j = ; j < n; j ++ ) {
if( !vis[j] ) {
if( dis[u] + mapn[u][j] < dis[j] ) {
pathnum[j] = pathnum[u];
dis[j] = dis[u] + mapn[u][j];
total[j] = total[u] + val[j];
path[j] = u;
} else if( dis[u] + mapn[u][j] == dis[j] ) {
pathnum[j] += pathnum[u];
if( total[j] < total[u] + val[j] ) {
total[j] = total[u] + val[j];
path[j] = u;
}
}
}
}
}
}
int main() {
while( cin >> n >> m >> s >> d ) {
for( int i = ; i < n; i ++ ) {
cin >> val[i];
}
for( int i = ; i < n; i ++ ) {
for( int j = ; j < n; j ++ ) {
mapn[i][j] = 1e9;
}
}
int x,y,l;
for( int i = ; i < m; i ++ ) {
cin >> x >> y >> l;
mapn[x][y] = min( mapn[x][y], l );
mapn[y][x] = mapn[x][y];
}
dijkstra( s );
int num = , cur = d;
while( cur != s ) {
re[num++] = cur;
cur = path[cur];
}
re[num++] = s;
cout << pathnum[d] << " " << total[d] << endl;
for( int i = num - ; i > ; i -- ) {
cout << re[i] << " ";
}
cout << re[] << endl;
}
return ;
}

最新文章

  1. 【积累篇:他山之石,把玉攻】解决XP 系统 .Net Framework 4安装时出现严重错误 (0x80070643)
  2. java获取cpu和内存
  3. Operational Amplifiers
  4. ApiResponse 在 Swagger 1 和Swagger 2中的不同
  5. hibernateValidate
  6. 在桌面chrome中调试android设备中的web页面
  7. String数组转List,List转String数组
  8. Asp.Net MVC 路由 - Asp.Net 编程 - 张子阳
  9. NPOI 教程 - 3.2 打印相关设置
  10. asp.net对word文档进行修改 对于使用word文档做模板编辑比较适用
  11. Dom4j之xPath
  12. 代码格式化工具Astyle配置
  13. OpenLayers学习笔记5——使用jQuery UI实现查询并标注(UI篇)
  14. Oracle Test 日志
  15. Server 2008 R2远程桌面授权,解决120天过期问题
  16. php垃圾回收
  17. oop编程思想简单理解
  18. jmeter测试计划元素执行顺序
  19. SWPU-ACM集训队周赛之组队赛(3-11)G题题解
  20. 1:httpd-2.2基础

热门文章

  1. 夯实Java基础(十一)——内部类
  2. [Pulsar系列] 10分钟学会Pulsar消息系统概念
  3. JAVA jobs
  4. 3、数组的声明及初始化(test1.java)
  5. http客户端-性能比较系列-第二篇-多线程
  6. ethtool工具使用实例
  7. Hibernate的执行流程
  8. 多线程 共享资源 同步锁 java
  9. Node.js爬虫实战 - 爬你喜欢的
  10. mysql注意事项