鱼C论坛

 找回密码
 立即注册
查看: 2383|回复: 0

[技术交流] PTA A_1030 Travel Plan

[复制链接]
发表于 2020-2-21 16:51:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
传送门:https://pintia.cn/problem-sets/9 ... /994805464397627392

解:
迪杰斯特拉 + DFS (模板)
  1. #include <cstdio>
  2. #include <climits>
  3. #include <vector>
  4. #include <algorithm>

  5. using namespace std;

  6. const int maxn = 510;

  7. int n, m, c1, c2;
  8. int G[maxn][maxn];
  9. int cost[maxn][maxn];
  10. int d[maxn];//存放最短路径长度
  11. bool vis[maxn];//是否访问过
  12. vector<int> pre[maxn];//存放顶点在最短路径中的前驱

  13. void DJS(int s)
  14. {
  15.     fill(d, d + n, INT_MAX);
  16.     d[s] = 0;

  17.     for (int i = 0; i < n; i++)
  18.     {   
  19.         int u = -1, min = INT_MAX;

  20.         for (int i = 0; i < n; i++)//查找未被访问过且距离最短的顶点
  21.             if (!vis[i] && d[i] < min)  min = d[u = i];

  22.         if (u == -1) return;//如果剩下的顶点与源点不通,返回

  23.         vis[u] = true;

  24.         for (int v = 0; v < n; v++)
  25.         {
  26.             if (vis[v] || G[u][v] == INT_MAX) continue;

  27.             int t = d[u] + G[u][v];

  28.             if (t < d[v])
  29.             {
  30.                 d[v] = t;
  31.                 pre[v].clear();
  32.                 pre[v].push_back(u);
  33.             }  
  34.             else if (t == d[v])
  35.                 pre[v].push_back(u);
  36.         }
  37.     }
  38. }

  39. int opt_cost = INT_MAX;//存放最少花费
  40. vector<int> path, temp_path;

  41. void DFS(int v)
  42. {
  43.     if (v == c1)//递归边界,如果遍历到起点
  44.     {
  45.         temp_path.push_back(v);

  46.         int val = 0;
  47.         for (int i = temp_path.size() - 1; i > 0; i--)
  48.             val += cost[temp_path[i]][temp_path[i - 1]];

  49.         if (val < opt_cost)
  50.         {
  51.             opt_cost = val;
  52.             path = temp_path;
  53.         }

  54.         temp_path.pop_back();

  55.         return;
  56.     }

  57.     temp_path.push_back(v);

  58.     for (int i = 0; i < pre[v].size(); i++)
  59.         DFS(pre[v][i]);

  60.     temp_path.pop_back();
  61. }

  62. int main(void)
  63. {
  64.     scanf("%d %d %d %d", &n, &m, &c1, &c2);
  65.    
  66.     fill(G[0], G[0] + maxn * maxn, INT_MAX);
  67.    
  68.     while (m--)
  69.     {
  70.         int a, b, l, c;
  71.         scanf("%d %d %d %d", &a, &b, &l, &c);

  72.         G[a][b] = G[b][a] = l;
  73.         cost[a][b] = cost[b][a] = c;
  74.     }

  75.     DJS(c1);
  76.     DFS(c2);

  77.     for (int i = path.size() - 1; i >= 0; i--)
  78.         printf("%d ", path[i]);

  79.     printf("%d %d", d[c2], opt_cost);

  80.     return 0;
  81. }
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-6 11:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表