【思路】

题目生词

figure

n. 数字

v. 认为,认定;计算;是……重要部分

The stations are represented by vertices and the roads correspond to the edges.

顶点表示车站,边表示道路。

correspond to 相当于

capacity

n. 能力;容量

题目大意:给出需要调整的车站编号,从0处出发,一路上顺便调整途径的车站,使得每个车站的车辆数是Cmax的一半,多的带走少的补齐。选最短路,最短相同选从0处带的车最少的路,若还相同则选择带回0处的车最少的路。

输出要带的车辆数,路径,带回的车辆数(返回时直接回,不再调整)。

方法:Dijkstra + DFS。先用Dijkstra算法算出最短路径,只考虑时间最短,建立vector保存路径的前驱节点。然后用DFS遍历每一条路径,获得一条路径后(即遍历到了起始节点0)计算带去带回的车辆,确定最佳方案。

计算带去、带回车辆数的方法:对于每个站点,考虑前一个站点传递下来的车辆数trans和自己的车辆数bike[i]相加的结果与cmax/2的差,分两种情况——一,差值为负,即车不够,要从0处带车,所以bring的值增加其差值的绝对值,而传递给下去的车辆数trans置为0;二,差值非负,表示车够了,多出的车赋值给trans传递到下一个站点,bring的值保持。一开始bring和trans的值为0,从出发节点的下一个节点(即0号节点的下一个节点)开始遍历计算。最终bring为要从0处携带的车辆数,trans即带回的车辆数。注意,有关从0处带多少车,只与当前走过的车站有关,即不管后面站点车再多,前面的车不够了,就要从0处带(因为走路不会回头,携带的车辆数是随着路径的推进而变化的)。而DFS是从终点向前推到起点结束,则必须要求完整条路径才能算的出来。最后倒着输出变长数组的值,即为路径。

【tips】要熟练运用Dijkstra+DFS求最佳路径的算法!

【AC代码】

  1. #define _CRT_SECURE_NO_WARNINGS
  2. #include<iostream>
  3. #include<vector>
  4. using namespace std;
  5. #define N 502
  6. #define INF 100000000
  7. int cmax, stations, goal, roads;
  8. int bike[N];
  9. int length[N][N] = { {} };
  10. bool vis[N] = {};
  11. int d[N];
  12. vector<int>pre[N];
  13. vector<int>path;
  14. int minbring = INF, minback = INF;
  15. vector<int>bestpath;
  16. void DFS(int v)
  17. {
  18. if (v == ) //到边界--起始节点。
  19. {
  20. //计算第二、三标尺的值,即带去、带回的车辆数。
  21. path.push_back(v);
  22. int bring = ;
  23. int trans = ;
  24. for (int i = path.size() - ; i >= ; i--)
  25. {
  26. int u = path[i];
  27. if (bike[u] + trans >= cmax / )
  28. {
  29. trans += bike[u] - cmax / ;
  30. }
  31. else
  32. {
  33. bring += cmax / - bike[u] - trans;
  34. trans = ;
  35. }
  36. }
  37. //更新最优值。
  38. if (bring < minbring)
  39. {
  40. bestpath = path;
  41. minbring = bring;
  42. minback = trans;
  43. }
  44. else if (bring == minbring)
  45. {
  46. if (trans < minback)
  47. {
  48. bestpath = path;
  49. minback = trans;
  50. }
  51. }
  52. path.pop_back();
  53. return;
  54. }
  55. int i;
  56. path.push_back(v);
  57. for (i = ; i < pre[v].size(); i++)
  58. {
  59. DFS(pre[v][i]);
  60. }
  61. path.erase(path.end() - );//可以写成path.pop_back();
  62. }
  63. void Dijkstra(int s)
  64. {
  65. int i, j;
  66. fill(d, d + N, INF);
  67. d[s] = ;
  68. for (i = ; i <= stations; i++)
  69. {
  70. //找不在s集中的d最小
  71. int min = INF, u = -;
  72. for (j = ; j <= stations; j++)
  73. {
  74. if (min > d[j] && vis[j] == )
  75. {
  76. min = d[j];
  77. u = j;
  78. }
  79. }
  80. if (u == -)return;
  81. vis[u] = true;
  82. //对于通过u能到s的点v,更新路径
  83. for (j = ; j <= stations; j++)
  84. {
  85. if (length[u][j] && vis[j] == )
  86. {
  87. if (d[u] + length[u][j] < d[j])
  88. {
  89. d[j] = d[u] + length[u][j];
  90. pre[j].clear();
  91. pre[j].push_back(u);
  92. }
  93. else if (d[u] + length[u][j] == d[j])
  94. {
  95. pre[j].push_back(u);
  96. }
  97. }
  98. }
  99.  
  100. }
  101. }
  102.  
  103. int main()
  104. {
  105. cin >> cmax >> stations >> goal >> roads;
  106. int i;
  107. for (i = ; i <= stations; i++)
  108. cin >> bike[i];
  109. for (i = ; i < roads; i++)
  110. {
  111. int u, v;
  112. cin >> u >> v;
  113. cin >> length[u][v];
  114. length[v][u] = length[u][v];
  115. }
  116. Dijkstra();
  117. DFS(goal);
  118. cout << minbring << "";
  119. for (i = bestpath.size() - ; i >= ; i--)
  120. {
  121. cout << "->" << bestpath[i];
  122. }
  123. cout << " " << minback;
  124. return ;
  125. }

[PAT] A1018 Public Bike Management的更多相关文章

  1. PAT A1018 Public Bike Management (30 分)——最小路径,溯源,二标尺,DFS

    There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...

  2. PAT 1018 Public Bike Management[难]

    链接:https://www.nowcoder.com/questionTerminal/4b20ed271e864f06ab77a984e71c090f来源:牛客网PAT 1018  Public ...

  3. PAT甲级——A1018 Public Bike Management

    There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...

  4. PAT 1018. Public Bike Management

    There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...

  5. A1018. Public Bike Management

    There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...

  6. PAT 1018 Public Bike Management(Dijkstra 最短路)

    1018. Public Bike Management (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yu ...

  7. pat 甲级 Public Bike Management

    Public Bike Management (30) 题目描述 There is a public bike service in Hangzhou City which provides grea ...

  8. PAT_A1018#Public Bike Management

    Source: PAT A1018 Public Bike Management (30 分) Description: There is a public bike service in Hangz ...

  9. PAT甲级1018. Public Bike Management

    PAT甲级1018. Public Bike Management 题意: 杭州市有公共自行车服务,为世界各地的游客提供了极大的便利.人们可以在任何一个车站租一辆自行车,并将其送回城市的任何其他车站. ...

随机推荐

  1. 【大白话系统】MySQL 学习总结 之 缓冲池(Buffer Pool) 的设计原理和管理机制

    一.缓冲池(Buffer Pool)的地位 在<MySQL 学习总结 之 InnoDB 存储引擎的架构设计>中,我们就讲到,缓冲池是 InnoDB 存储引擎中最重要的组件.因为为了提高 M ...

  2. Codeforces Round #617 (Div. 3) D. Fight with Monsters

    D : Fight with Monsters 题目大意 : 有一组数,每个值对应着一个怪物的 hp 值,现在有两个人,一个自己一个对手,每个人有一个攻击值, 两个人轮流攻击怪物,如果是自己将怪物先打 ...

  3. Java范型学习笔记

    对于范型的使用或者说印象只有集合,其他地方即使使用过也不知道,反正就是只停留在List<E> Map<K, V>,最近刚好闲来无事,就找找资料学习一下:下列为个人学习总结,欢迎 ...

  4. Python3(七) 正则表达式与JSON

    一. 初识正则表达式 1.定义:是一个特殊的字符序列,可以帮助检测一个字符串是否与我们所设定的字符序列相匹配. 2.作用:可以实现快速检索文本.实现替换文本的操作. 3.场景: 1.检测一串数字是否是 ...

  5. Hapi+MySql项目实战自动化文档生成(四)

    自动化生成swagger文档 使用hapi插件hapi-swagger,简单配置下插件,先修改下plugin_config.js文件: //plugin_config.js const Swagger ...

  6. ELF文件之八——使用链接脚本-2个函数-data-bss-temp-call-debug信息

    gcc编译选项可以设置生成调试信息, debug信息格式有stabs,coff,xcoff,dwarf. 常用的有两种格式,stab和dwarf,stab较早,dwarf较新.两种格式介绍:https ...

  7. Android studio 断点调试整理

    一. 开始断点调试 点击debug开始调试

  8. 你应该了解的 Java SPI 机制

    前言 不知大家现在有没有去公司复工,我已经在家办公将近 3 周了,同时也在家呆了一个多月:还好工作并没有受到任何影响,我个人一直觉得远程工作和 IT 行业是非常契合的,这段时间的工作效率甚至比在办公室 ...

  9. 学习shiro最佳实践,绝对正确

    按照https://blog.csdn.net/qq_34021712/column/info/26947学习,基本能解决shiro一切问题,谢谢该博主

  10. python制作ico图标

    import PythonMagick img = PythonMagick.Image('image.png') img.sample('64x64') img.write('image_64x64 ...