鱼C论坛

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

[技术交流] PTA A_1087 All Roads Lead to Rome

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

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

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

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

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

  7. using namespace std;

  8. const int maxn = 210;

  9. int n, k;
  10. int d[maxn];
  11. int pw[maxn];
  12. bool vis[maxn];
  13. int G[maxn][maxn];
  14. vector<int> pre[maxn];
  15. map<string, int> s2n;
  16. map<int, string> n2s;

  17. void DJS(void)
  18. {
  19.     fill(d, d + maxn, INT_MAX);
  20.     memset(vis, false, sizeof(vis));

  21.     d[0] = 0;

  22.     for (int i = 0; i < n; i++)
  23.     {
  24.         int u  = -1, min = INT_MAX;

  25.         for (int j = 0; j <= n; j++)
  26.             if (!vis[j] && d[j] < min) min = d[u = j];

  27.         if (u == -1) return;

  28.         vis[u] = true;

  29.         for (int v = 0; v <= n; v++)
  30.         {
  31.             if (vis[v] || G[u][v] == INT_MAX) continue;

  32.             if (G[u][v] + d[u] < d[v])
  33.             {
  34.                 d[v] = G[u][v] + d[u];
  35.                 pre[v].clear();
  36.                 pre[v].push_back(u);
  37.             }
  38.             else if (G[u][v] + d[u] == d[v])
  39.                 pre[v].push_back(u);
  40.         }
  41.     }
  42. }

  43. vector<int> path, temp_path;
  44. int opt_w = -1;
  45. int routes = 0;

  46. void DFS(int id)
  47. {
  48.     if (!id)
  49.     {
  50.         int happy = 0;

  51.         routes++;

  52.         for (int i = temp_path.size() - 1; i >= 0; i--)
  53.             happy += pw[temp_path[i]];

  54.         if (happy > opt_w)
  55.         {
  56.             path = temp_path;
  57.             opt_w = happy;
  58.         }
  59.     }

  60.     temp_path.push_back(id);
  61.    
  62.     for (int i = 0; i < pre[id].size(); i++)
  63.         DFS(pre[id][i]);

  64.     temp_path.pop_back();
  65. }

  66. int main(void)
  67. {
  68.     // freopen("input.txt", "r", stdin);
  69.     string s;
  70.     cin >> n >> k >> s;

  71.     n2s[0] = s;
  72.     s2n[s] = 0;
  73.         
  74.     for (int i = 1; i < n; i++)
  75.     {
  76.         cin >> s >> pw[i];

  77.         n2s[i] = s;
  78.         s2n[s] = i;
  79.     }

  80.     fill(G[0], G[0] + maxn * maxn, INT_MAX);
  81.    
  82.     while (k--)
  83.     {
  84.         string s1, s2;
  85.         int cost;

  86.         cin >> s1 >> s2 >> cost;

  87.         int a = s2n[s1], b = s2n[s2];

  88.         G[a][b] = G[b][a] = cost;
  89.     }

  90.     DJS();
  91.     DFS(s2n["ROM"]);

  92.     cout << routes << " " << d[s2n["ROM"]] << " " << opt_w << " " << opt_w / path.size() << endl;

  93.     cout << n2s[0];
  94.     for (int i = path.size() - 1; i >= 0; i--)
  95.         cout << "->" << n2s[path[i]];
  96.         
  97.     return 0;
  98. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-14 03:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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