ACDream 1209 - qj的招待会

思路

单源最短路。从终点Dijkstra一遍就行。

代码

 
 
  1. ​#include <cstdio>
  2. #include <algorithm>
  3. #include <functional>
  4. #include <stack>
  5. #include <iostream>
  6. #include <string>
  7. #include <vector>
  8. #include <queue>
  9. #include <cstring>
  10. #include <string>
  11. #include <sstream>
  12. #include <map>
  13. #include <cmath>
  14. #define LL long long
  15. #define lowbit(x) ((x) & (-x))
  16. #define MP(a, b) make_pair(a, b)
  17. const int MAXN = 1000 + 5;
  18. const int INF = 0x3f3f3f3f;
  19. using namespace std;
  20. typedef pair<int, int> pii;
  21. typedef vector<int>::iterator viti;
  22. typedef vector<pii>::iterator vitii;
  23. vector<pii> mp[MAXN];
  24. priority_queue<pii, vector<pii>, greater<pii> >pqu;
  25. int d[MAXN];
  26. void Dijkstra(int st)
  27. {
  28. memset(d, INF, sizeof d);
  29. d[st] = 0;
  30. pqu.push(MP(d[st], st));
  31. while (!pqu.empty())
  32. {
  33. pii u = pqu.top(); pqu.pop();
  34. int x = u.second, curDis = u.first;
  35. if (u.first != d[x]) continue;
  36. for (vitii it = mp[x].begin(); it != mp[x].end(); it++)
  37. {
  38. int t = it->first;
  39. if (d[t] > curDis + it->second)
  40. {
  41. d[t] = curDis + it->second;
  42. pqu.push(MP(d[t], t));
  43. }
  44. }
  45. }
  46. }
  47. int main()
  48. {
  49. int n, i, j;
  50. scanf("%d", &n);
  51. for (i = 0; i < n; i++)
  52. {
  53. char ch[10], cch[10];
  54. int dis, a, b;
  55. scanf("%s%s%d", ch, cch, dis);
  56. if (isupper(ch[0])) a = ch[0]- 'A' + 26;
  57. else a = ch[0] - 'a';
  58. if (isupper(cch[0])) b = ch[0] - 'A' + 26;
  59. else b = cch[0] - 'a';
  60. mp[a].push_back(MP(b, dis)); mp[b].push_back(MP(a, dis));
  61. int st = 'Z' - 'A';
  62. Dijkstra(st);
  63. int pos, ans = INF;
  64. for (i = 0; i < 55; i++)
  65. {
  66. ans = min(ans, d[i]);
  67. pos = i;
  68. }
  69. printf("%c %d\n", pos + 'A', ans);
  70. }
  71. return 0;
  72. }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值