鱼C论坛

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

[技术交流] PTA A_1018 Public Bike Management

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

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

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

x
传送门:https://pintia.cn/problem-sets/994805342720868352/problems/994805489282433024

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

  6. using namespace std;

  7. const int maxn = 510;

  8. int c_max, n, sp, m;
  9. int pw[maxn];
  10. int d[maxn];
  11. bool vis[maxn];
  12. int G[maxn][maxn];
  13. vector<int> pre[maxn];

  14. void DJS(void)
  15. {
  16.     fill(d, d + maxn, INT_MAX);
  17.     memset(vis, false, sizeof(vis));

  18.     d[0] = 0;

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

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

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

  25.         vis[u] = true;

  26.         for (int v = 1; v <= n; v++)
  27.         {
  28.             if (vis[v] || G[u][v] == INT_MAX) continue;

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

  40. vector<int> path, temp_path;
  41. int send = INT_MAX, back = INT_MAX;

  42. void DFS(int id)
  43. {
  44.     if (!id)
  45.     {
  46.         int sen = 0, bac = 0;

  47.         for (int i = temp_path.size() - 1; i >= 0; i--)
  48.         {
  49.             bac += pw[temp_path[i]];

  50.             if (bac < 0)
  51.             {
  52.                 sen -= bac;
  53.                 bac = 0;
  54.             }
  55.         }

  56.         if (sen < send || (sen == send && bac < back))
  57.         {
  58.             path = temp_path;
  59.             send = sen;
  60.             back = bac;
  61.         }
  62.     }

  63.     temp_path.push_back(id);

  64.     for (int i = 0; i < pre[id].size(); i++)
  65.         DFS(pre[id][i]);
  66.    
  67.     temp_path.pop_back();
  68. }

  69. int main(void)
  70. {
  71.     // freopen("input.txt", "r", stdin);
  72.     scanf("%d %d %d %d", &c_max, &n, &sp, &m);

  73.     for (int i = 1; i <= n; i++)
  74.     {
  75.         scanf("%d", pw + i);
  76.         pw[i] -= c_max / 2;
  77.     }
  78.         
  79.     fill(G[0], G[0] + maxn * maxn, INT_MAX);
  80.    
  81.     while (m--)
  82.     {
  83.         int a, b, l;
  84.         scanf("%d %d %d", &a, &b, &l);

  85.         G[a][b] = G[b][a] = l;
  86.     }

  87.     DJS();
  88.     DFS(sp);

  89.     printf("%d 0", send);
  90.     for (int i = path.size() - 1; i >= 0; i--)
  91.         printf("->%d", path[i]);

  92.     printf(" %d", back);

  93.     return 0;
  94. }
复制代码

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-5 03:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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