德克萨斯纯朴的民众们这个夏天正在遭受巨大的热浪!!!
他们的德克萨斯长角牛吃起来不错,可是它们并不是很擅长生产富含奶油的乳制品。
农夫John此时身先士卒地承担起向德克萨斯运送大量的营养冰凉的牛奶的重任,以减轻德克萨斯人忍受酷暑的痛苦。
John已经研究过可以把牛奶从威斯康星运送到德克萨斯州的路线。
这些路线包括起始点和终点一共有 TT 个城镇,为了方便标号为 11 到 TT。
除了起点和终点外的每个城镇都由 双向道路 连向至少两个其它的城镇。
每条道路有一个通过费用(包括油费,过路费等等)。
给定一个地图,包含 CC 条直接连接 22 个城镇的道路。
每条道路由道路的起点 RsRs,终点 ReRe 和花费 CiCi 组成。
求从起始的城镇 TsTs 到终点的城镇 TeTe 最小的总费用。

输入格式

第一行: 44 个由空格隔开的整数: T,C,Ts,TeT,C,Ts,Te;
第 22 到第 C+1C+1 行: 第 i+1i+1 行描述第 ii 条道路,包含 33 个由空格隔开的整数: Rs,Re,CiRs,Re,Ci。

输出格式

一个单独的整数表示从 TsTs 到 TeTe 的最小总费用。
数据保证至少存在一条道路。

数据范围

1≤T≤25001≤T≤2500,
1≤C≤62001≤C≤6200,
1≤Ts,Te,Rs,Re≤T1≤Ts,Te,Rs,Re≤T,
1≤Ci≤10001≤Ci≤1000

输入样例:

  1. 7 11 5 4
  2. 2 4 2
  3. 1 4 3
  4. 7 2 2
  5. 3 4 3
  6. 5 7 5
  7. 7 3 3
  8. 6 1 1
  9. 6 3 4
  10. 2 4 3
  11. 5 6 3
  12. 7 2 1

输出样例:

  1. 7

代码

  1. #include <iostream>
  2. #include <cstring>
  3. #include <queue>
  4. using namespace std;
  5. const int N = 1e5, INF = 0x3f3f3f3f;
  6. int n, m, S, E;
  7. int h[N], e[N], w[N], ne[N], idx;
  8. int d[N];
  9. bool st[N];
  10. void add(int a, int b, int c){
  11. e[idx] = b, w[idx] = c, ne[idx] = h[a], h[a] = idx ++;
  12. }
  13. void spfa(int s){
  14. memset(d, 0x3f, sizeof d);
  15. d[s] = 0;
  16. queue<int> q;
  17. q.push(s);
  18. st[s] = true;
  19. while(q.size()){
  20. int t = q.front();
  21. q.pop();
  22. st[t] = false;
  23. for(int i = h[t]; i != -1; i = ne[i]){
  24. int j = e[i];
  25. if(d[j] > d[t] + w[i]){
  26. d[j] = d[t] + w[i];
  27. if(!st[j]){
  28. st[j] = true;
  29. q.push(j);
  30. }
  31. }
  32. }
  33. }
  34. }
  35. int main(){
  36. memset(h, -1, sizeof h);
  37. cin >> n >> m >> S >> E;
  38. for(int i = 0; i < m; i ++){
  39. int a, b, c;
  40. cin >> a >> b >> c;
  41. add(a, b, c), add(b, a, c);
  42. }
  43. spfa(S);
  44. cout << d[E];
  45. return 0;
  46. }