鱼C论坛

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

[技术交流] PTA A_1072 Gas Station

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

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

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

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

解:
迪杰斯特拉
  1. #include <cstdio>
  2. #include <climits>
  3. #include <cstring>
  4. #include <algorithm>

  5. using namespace std;

  6. const int maxn = 1050;

  7. int n, m, k, ds;
  8. int d[maxn];
  9. bool vis[maxn];
  10. int G[maxn][maxn];

  11. int trans(char *s)
  12. {
  13.     int id;

  14.     if (*s == 'G')
  15.     {
  16.         sscanf(s + 1, "%d", &id);
  17.         id += n;
  18.     }
  19.     else
  20.         sscanf(s, "%d", &id);

  21.     return id;
  22. }

  23. void DJS(int st)
  24. {
  25.     fill(d, d + maxn, INT_MAX);
  26.     memset(vis, false, sizeof(vis));

  27.     d[st] = 0;

  28.     for (int i = 1; i < n + m; i++)
  29.     {
  30.         int u  = -1, min = INT_MAX;

  31.         for (int j = 1; j <= n + m; j++)
  32.             if (!vis[j] && d[j] < min) min = d[u = j];

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

  34.         vis[u] = true;

  35.         for (int v = 1; v <= n + m; v++)
  36.         {
  37.             if (vis[v] || G[u][v] == INT_MAX) continue;
  38.             if (G[u][v] + d[u] < d[v]) d[v] = G[u][v] + d[u];
  39.         }
  40.     }
  41. }

  42. int main(void)
  43. {
  44.     // freopen("input.txt", "r", stdin);
  45.     scanf("%d %d %d %d", &n, &m, &k, &ds);
  46.         
  47.     fill(G[0], G[0] + maxn * maxn, INT_MAX);
  48.    
  49.     while (k--)
  50.     {
  51.         char s1[5], s2[5];
  52.         int a, b, l;

  53.         scanf("%s %s %d", s1, s2, &l);
  54.         a = trans(s1);
  55.         b = trans(s2);

  56.         G[a][b] = G[b][a] = l;
  57.     }

  58.     int max_id = -1, max = INT_MIN;
  59.     double ave[maxn];

  60.     for (int i = n + 1; i <= n + m; i++)
  61.     {
  62.         DJS(i);

  63.         int temp = d[1], total = 0;
  64.         bool flag = false;
  65.         for (int j = 1; j <= n; j++)
  66.         {
  67.             if (d[j] > ds)
  68.             {
  69.                 flag = true;
  70.                 break;
  71.             }

  72.             total += d[j];
  73.             if (d[j] < temp) temp = d[j];
  74.         }

  75.         if (flag) continue;

  76.         ave[i] = (double)total / (double)n;   

  77.         if (temp > max || (temp == max && ave[i] < ave[max_id]))
  78.         {
  79.             max = temp;
  80.             max_id = i;
  81.         }
  82.     }

  83.     if (max_id == -1) puts("No Solution");
  84.     else printf("G%d\n%.1f %.1f\n", max_id - n, (double)max, ave[max_id]);
  85.    
  86.     return 0;
  87. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-12 13:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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