https://www.patest.cn/contests/gplt/L2-001

题解:求最短路的条数,并输出点的权值最大的路径,用priority_queue会wa两个点,原因不明。

    于是又学了另外一种dijkstra

坑:L3的天梯地图是同一个模板的题目,结果代码交上去有一个点过不了。。。。

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <algorithm>
  4. #include <queue>
  5. #include <vector>
  6. #include <math.h>
  7. #include <string.h>
  8. #include <string>
  9. #include <map>
  10. #include<stack>
  11. #include<set>
  12. #include<string.h>
  13. #define pb push_back
  14. #define _for(i, a, b) for (int i = (a); i<(b); ++i)
  15. #define _rep(i, a, b) for (int i = (a); i <= (b); ++i)
  16.  
  17. using namespace std;
  18. const int N = + ;
  19.  
  20. int num[N];
  21. int E[N][N];
  22. int dis[N];
  23. vector<int> path;
  24. int ans[N];
  25. int sum[N];
  26. int last[N];
  27. void init() {
  28. _for(i, , N) {
  29. dis[i] = 1e9;
  30. //ans[i] = 1;
  31.  
  32. }
  33. }
  34. int main() {
  35. init();
  36. memset(E, -, sizeof(E));
  37. int n;
  38. int m, s, d;
  39. cin >> n >> m >> s >> d;
  40. set<int>vis;
  41. _for(i, , n) {
  42. cin >> num[i]; sum[i] = num[i]; vis.insert(i);
  43. }
  44. _for(i, , m) {
  45. int x, y, z;
  46. cin >> x >> y >> z;
  47. E[x][y] = E[y][x] = z;
  48. }
  49.  
  50. last[s] = -; ans[s] = ; dis[s] = ;
  51. for (int now = s; vis.size()>; vis.erase(now)) {
  52. int mn = 1e9;
  53. _for(i, , n) {
  54. if (dis[i] < mn&&vis.count(i) == ) {
  55. now = i;
  56. mn = dis[i];
  57. }
  58. }
  59. _for(j, , N) if(E[now][j]!=-){
  60.  
  61. if (dis[j] > dis[now] + E[now][j]) {
  62. dis[j] = dis[now] + E[now][j];
  63. last[j] = now;
  64. sum[j] = sum[now] + num[j];
  65. ans[j] = ans[now];
  66. }
  67. else if (dis[j] == dis[now] + E[now][j]) {
  68. ans[j] += ans[now];
  69. if (sum[j] < sum[now] + num[j]) {
  70. last[j] = now;
  71. sum[j] = sum[now] + num[j];
  72. }
  73. }
  74. }
  75. }
  76.  
  77. cout << ans[d] << ' ' << sum[d] << endl;
  78. stack<int>st;
  79. for (int i = d; i != -; i = last[i]) {
  80. st.push(i);
  81. }
  82.  
  83. cout << st.top(); st.pop();
  84. while (!st.empty()) { cout << ' ' << st.top(); st.pop(); }
  85.  
  86. system("pause");
  87.  
  88. }

附上wa2的代码,以后研究(求助)

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <algorithm>
  4. #include <queue>
  5. #include <vector>
  6. #include <math.h>
  7. #include <string.h>
  8. #include <string>
  9. #include <map>
  10. #include<stack>
  11. #define pb push_back
  12. #define _for(i, a, b) for (int i = (a); i<(b); ++i)
  13. #define _rep(i, a, b) for (int i = (a); i <= (b); ++i)
  14.  
  15. using namespace std;
  16. const int N = +;
  17.  
  18. int num[N];
  19. vector< pair<int, int> > E[N];
  20. int dis[N];
  21. vector<int> path[N];
  22. int ans[N];
  23. int sum[N];
  24. int last[N];
  25.  
  26. void init() {
  27. _for(i, , N) {
  28. dis[i] = 1e9;
  29. ans[i] = ;
  30. //last[i] = -1;
  31. }
  32. }
  33. int main() {
  34. init();
  35. int n;
  36. int m, s, d;
  37. cin >> n >> m >> s >> d;
  38. _for(i, , n) { cin >> num[i]; sum[i] = num[i]; }
  39. _for(i, , m) {
  40. int x, y, z;
  41. cin >> x >> y >> z;
  42. E[x].pb(make_pair(y, z));
  43. E[y].pb(make_pair(x, z));
  44.  
  45. }
  46. priority_queue<pair<int, int> >Q;
  47. dis[s] = ;
  48. path[s].pb(s);
  49. Q.push(make_pair(-dis[s], s)); last[s] = -;
  50. while (!Q.empty()) {
  51. int now = Q.top().second;
  52. Q.pop();
  53. _for(i, , E[now].size()) {
  54. int v = E[now][i].first;//about update the node,consider every step we enumerate all the nodes linked to the priority node ,if it is better put it into a vector temporarily.
  55. if (dis[v] > dis[now] + E[now][i].second) {
  56. dis[v] = dis[now] + E[now][i].second;
  57. last[v] = now;
  58. sum[v] = sum[now] + num[v];
  59. ans[v] = ans[now];
  60. Q.push(make_pair(-dis[v], v));
  61. //here is the problem ,when we update dis,it's easy,but about path,we need to change the before ones
  62. }
  63. else if (dis[v] == dis[now] + E[now][i].second) {
  64. ans[v] += ans[now];
  65. if (sum[v]<sum[now]+num[v]) {
  66. last[v] = now;
  67. sum[v] = sum[now] + num[v];
  68. Q.push(make_pair(-dis[v], v)
  69. }
  70.  
  71. }
  72. }
  73. }
  74. cout << ans[d] << ' ' << sum[d] << endl;
  75. stack<int> st;
  76. for (int i = d; i != -; i = last[i]) {
  77. st.push(i);
  78. }
  79. cout << st.top(); st.pop();
  80. while (!st.empty()) { cout <<' '<< st.top(); st.pop(); }
  81. system("pause");
  82.  
  83. }

L3的天梯地图:

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <algorithm>
  4. #include <queue>
  5. #include <vector>
  6. #include <math.h>
  7. #include <string.h>
  8. #include <string>
  9. #include <map>
  10. #include<stack>
  11. #include<set>
  12. #include<string.h>
  13. #define pb push_back
  14. #define _for(i, a, b) for (int i = (a); i<(b); ++i)
  15. #define _rep(i, a, b) for (int i = (a); i <= (b); ++i)
  16.  
  17. using namespace std;
  18. const int N = + ;
  19.  
  20. int num[N];
  21. int E[N][N],R[N][N];
  22. int dis[N];
  23. int di[N];
  24. vector<int> path;
  25. int ans[N];
  26. int sum[N];
  27. int last[N];
  28. void init() {
  29. _for(i, , N) {
  30. dis[i] = 1e9;
  31. //ans[i] = 1;
  32. di[i] = 1e9;
  33. }
  34. }
  35. int main() {
  36. init();
  37. memset(E, -, sizeof(E));
  38. int n;
  39. int m, s, d;
  40. cin >> n >> m;
  41. set<int>vis;
  42. _for(i, , n) {
  43. sum[i] = ; vis.insert(i); num[i] = ;
  44. }
  45. _for(i, , m) {
  46. int x, y, z;
  47. cin >> x >> y >> z;
  48. int len, tim;
  49. cin >> len >> tim;
  50. if (z == )
  51. E[x][y] = E[y][x] = len;
  52. else E[x][y] = len;
  53. if (z == )
  54. R[x][y] = R[y][x] = tim;
  55. else R[x][y] = tim;
  56. }
  57. cin >> s >> d;
  58.  
  59. _for(i, , n) {
  60. sum[i] = ; vis.insert(i); num[i] = ;
  61. }
  62. last[s] = -; ans[s] = ; di[s] = ;
  63. for (int now = s; vis.size()>; vis.erase(now)) {
  64. int mn = 1e9;
  65. _for(i, , n) {
  66. if (di[i] < mn&&vis.count(i) == ) {
  67. now = i;
  68. mn = di[i];
  69. }
  70. }
  71. _for(j, , N) if (E[now][j] != -) {
  72.  
  73. if (di[j] > di[now] + R[now][j]) {
  74. di[j] = di[now] + R[now][j];
  75. last[j] = now;
  76. sum[j] = sum[now] + num[j];
  77. ans[j] = ans[now];
  78. }
  79. else if (di[j] == di[now] + R[now][j]) {
  80. ans[j] += ans[now];
  81. if (sum[j] > sum[now] + num[j]) {
  82. last[j] = now;
  83. sum[j] = sum[now] + num[j];
  84. }
  85. }
  86. }
  87. }
  88.  
  89. stack<int> st1;
  90. for (int i = d; i != -; i = last[i]) {
  91. st1.push(i);
  92. }
  93.  
  94. //printf("Time = %d: ", di[d]);
  95. //cout << st.top(); st.pop();
  96. //while (!st.empty()) { cout << " => " << st.top(); st.pop(); }
  97. //cout << endl;
  98.  
  99. _for(i, , n) {
  100. sum[i] = ; vis.insert(i); num[i] = ;
  101. }
  102. last[s] = -; ans[s] = ; dis[s] = ;
  103. for (int now = s; vis.size()>; vis.erase(now)) {
  104. int mn = 1e9;
  105. _for(i, , n) {
  106. if (dis[i] < mn&&vis.count(i) == ) {
  107. now = i;
  108. mn = dis[i];
  109. }
  110. }
  111. _for(j, , N) if (E[now][j] != -) {
  112.  
  113. if (dis[j] > dis[now] + E[now][j]) {
  114. dis[j] = dis[now] + E[now][j];
  115. last[j] = now;
  116. sum[j] = sum[now] + num[j];
  117. ans[j] = ans[now];
  118. }
  119. else if (dis[j] == dis[now] + E[now][j]) {
  120. ans[j] += ans[now];
  121. if (sum[j] > sum[now] + num[j]) {
  122. last[j] = now;
  123. sum[j] = sum[now] + num[j];
  124. }
  125. }
  126. }
  127. }
  128.  
  129. stack<int> st2;
  130. for (int i = d; i != -; i = last[i]) {
  131. st2.push(i);
  132. }
  133. if (st1 == st2) {
  134. printf("Time = %d; Distance = %d: ", di[d],dis[d]);
  135. cout << st2.top(); st2.pop();
  136. while (!st2.empty()) { cout << " => " << st2.top(); st2.pop(); }
  137. }
  138. else {
  139. printf("Time = %d: ", di[d]);
  140. cout << st1.top(); st1.pop();
  141. while (!st1.empty()) { cout << " => " << st1.top(); st1.pop(); }
  142. cout << endl;
  143. printf("Distance = %d: ", dis[d]);
  144. cout << st2.top(); st2.pop();
  145. while (!st2.empty()) { cout << " => " << st2.top(); st2.pop(); }
  146. cout << endl;
  147. }
  148. system("pause");
  149.  
  150. }

CCCC L2-001 紧急救援 floyd改的dijkstra模板 (记录路径) L3 天梯地图的更多相关文章

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

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

  2. L2-001. 紧急救援---(Dijkstra,记录路径)

    https://www.patest.cn/contests/gplt/L2-001 L2-001. 紧急救援 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 ...

  3. [Python] 弗洛伊德(Floyd)算法求图的直径并记录路径

    相关概念 对于一个图G=(V, E),求图中两点u, v间最短路径长度,称为图的最短路径问题.最短路径中最长的称为图的直径. 其中,求图中确定的某两点的最短路径算法,称为单源最短路径算法.求图中任意两 ...

  4. HDU-2544 最短路 Dijkstra模板题

    题目链接:https://vjudge.net/problem/HDU-2544 题意: 题目要求找到节点1到节点n之间的一条最短路 分析: Dijkstra模板题 单源最短路径,可以用dijkstr ...

  5. Minimum Transport Cost(floyd+二维数组记录路径)

    Minimum Transport Cost Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/O ...

  6. 训练指南 UVA - 11374(最短路Dijkstra + 记录路径 + 模板)

    layout: post title: 训练指南 UVA - 11374(最短路Dijkstra + 记录路径 + 模板) author: "luowentaoaa" catalo ...

  7. HDU-1595Find the longest of shortest(最短路径的最长路Dijkstra+记录路径)

    Marica is very angry with Mirko because he found a new girlfriend and she seeks revenge.Since she do ...

  8. HDU 2544 最短路(floyd+bellman-ford+spfa+dijkstra队列优化)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目大意:找点1到点n的最短路(无向图) 练一下最短路... dijkstra+队列优化: #i ...

  9. L2-001. 紧急救援 (Dijkstra算法打印路径)

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

随机推荐

  1. 【GIS】postgres(postgis) --》nodejs+express --》geojson --》leaflet

    一.基本架构 1.数据存储层:PostgreSQL-9.2.13 + postgis_2_0_pg92 2.业务处理层:Nodejs + Express + PG驱动 3.前端展示层:Leaflet ...

  2. WAF Bypass数据库特性(MSsql探索篇)

    0x01 背景 探索玩了Mysql特性,继续来探索一下MSsql特性. 0x02 测试 常见有5个位置即:select * from admin where id=1[位置一]union[位置二]se ...

  3. 【RF库XML测试】通过xpath查找元素的说明

    Tag names:当仅使用1个tag的时候,xpath匹配具有该标签名称的所有直接子元素. Paths:通过/符号连接tag名称,例如second/child将匹配父元素second下所有的chil ...

  4. nessus 激活码

    nessus激活码的申请 nessus屏蔽了中国的激活码申请,中国IP申请的时候会直接跳转到购买商业版的页面. 解决方法: 使用IE代理或者VPN,用美国的IP最好,然后访问网址: http://ww ...

  5. 解决“Connection to https://dl-ssl.google.com refused”问题

    相信一些人刚开始搞android的安装开发环境的时候会遇到:Failed to fectch URl https://dl-ssl.google.com/android/repository/addo ...

  6. [Ubuntu] 关于使用 root 账号登录

    (本文验证环境为 Ubuntu 14.04 和 Lubuntu 13.04) Ubuntu 维护者们认为实在没有必要使用 root 帐户,因为你想做的所有事情管理员都可以完成,管理员只需使用 sudo ...

  7. springboot 集成elasticsearch

    In this article, we will discuss about “How to create a Spring Boot + Spring Data + Elasticsearch Ex ...

  8. 《C++标准程序库》笔记之二

    <C++标准程序库>笔记之二 本篇博客笔记顺序大体按照<C++标准程序库(第1版)>各章节顺序编排. ------------------------------------- ...

  9. css媒体查询来书写二倍图三倍图设置

    @media (-webkit-min-device-pixel-ratio: 2){} @media (-webkit-min-device-pixel-ratio: 3){}

  10. Java网络编程之查找Internet地址

    一.概述 连接到Internet上计算机都有一个称为Internet地址或IP地址的唯一的数来标识.由于IP很难记住,人们设计了域名系统(DNS),DNS可以将人们可以记忆的主机名与计算机可以记忆的I ...