CJOJ 1160 熱浪

熱浪

Description

得克薩斯淳樸的民衆們這個夏天正在遭受巨大的熱浪!!!他們的得克薩斯長角牛吃起來不錯,可是他們並不是很擅長生產富含奶油的乳製品。Farmer John此時以先天下之憂而憂,後天下之樂而樂的精神,身先士卒地承擔起向得克薩斯運送大量的營養冰涼的牛奶的重任,以減輕得克薩斯人忍受酷暑的痛苦。

FJ已經研究過可以把牛奶從威斯康星運送到得克薩斯州的路線。這些路線包括起始點和終點先一共經過T (1 <= T <= 2,500)個城鎮,方便地標號爲1到T。除了起點和終點外地每個城鎮由兩條雙向道路連向至少兩個其它地城鎮。每條道路有一個通過費用(包括油費,過路費等等)。

考慮這個有7個城鎮的地圖。城鎮5是奶源,城鎮4是終點(括號內的數字是道路的通過費用)。

P

經過路線5-6-3-4總共需要花費3 (5->6) + 4 (6->3) + 3 (3->4) = 10的費用。

給定一個地圖,包含C (1 <= C <= 6,200)條直接連接2個城鎮的道路。每條道路由道路的起點Rs,終點Re (1 <= Rs <= T; 1 <= Re <= T),和花費(1 <= Ci <= 1,000)組成。求從起始的城鎮Ts (1 <= Ts <= T)到終點的城鎮Te(1 <= Te <= T)最小的總費用。

Input

第一行: 4個由空格隔開的整數: T, C, Ts, Te
* 第2到第C+1行: 第i+1行描述第i條道路。有3個由空格隔開的整數: Rs, Re和Ci。

Output

第一行: 一個單獨的整數表示Ts到Te的最短路的長度。(不是費用麼?怎麼突然變直白了 ——譯者注)數據保證至少存在一條道路。

Sample Input

7 11 5 4
2 4 2
1 4 3
7 2 2
3 4 3
5 7 5
7 3 3
6 1 1
6 3 4
2 4 3
5 6 3
7 2 1

Sample Output

7

Hint

輸出細節:
5->6->1->4 (3 + 1 + 3)

Source

[USACO Oct09]
圖論,最短路

Solution

從起點開始spfa最後輸出終點的距離即可,不清楚用Dijkstra的情況,我一開始用Floyed是T飛了的

Code

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <stack>
#include <map>
#include <vector>
#include <queue>
#define L 2510
#define LL long long
using namespace std;

struct node{
  int nxt, to, w;
}e[6300 << 1];
int t, c, st, se, a, b, v, cnt;
int d[L], head[L];
bool vis[L];
queue <int> q;

inline void add(int a, int b, int v) {
  e[++cnt].nxt = head[a], e[cnt].to = b, e[cnt].w = v, head[a] = cnt;
}

int main(){
  freopen("CJOJ1160.in", "r", stdin);
  freopen("CJOJ1160.out", "w", stdout);
  scanf("%d %d %d %d", &t, &c, &st, &se);
  for (int i = 1; i <= t; ++i) d[i] = 2000000009;
  for (int i = 1; i <= c; ++i) {
    scanf("%d %d %d", &a, &b, &v);
    add(a, b, v), add(b, a, v);
  }
  d[st] = 0, q.push(st), vis[st] = 1;
  while (!q.empty()) {
    int x = q.front();
    q.pop(), vis[x] = 0;
    for (int i = head[x]; i; i = e[i].nxt) {
      int y= e[i].to;
      if (d[y] > d[x] + e[i].w) {
	d[y] = d[x] + e[i].w;
	if (!vis[y]) vis[y] = 1, q.push(y);
      }
    }
  }
  printf("%d\n", d[se]);
  return 0;
}

Summary

注意存邊的時候的數據範圍,一開始的數組開小了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章