裸的最短路呢。。。
建图还是有些微妙的。。。但是感觉不快啊。。。
每个时间点建一个点,然后我们建图分两步:
(1)i 时间点向 i - 1 号时间点连一条有向边
(2)若有一头牛[l, r],则 l - 1向 r连一条边
最后答案就是dis[T]
想想就觉得非常巧妙。。。但是慢啊。。。
1 /************************************************************** 2 Problem: 3389 3 User: rausen 4 Language: C++ 5 Result: Accepted 6 Time:652 ms 7 Memory:33064 kb 8 ****************************************************************/ 9 10 #include <cstdio> 11 #include <algorithm> 12 #include <vector> 13 #include <queue> 14 15 using namespace std; 16 const int inf = (int) 1e9; 17 const int N = 1000005; 18 const int M = N * 2; 19 struct edges{ 20 int next, to, v; 21 } e[M]; 22 struct heap_node{ 23 int v, to; 24 } NODE; 25 inline bool operator < (const heap_node &a, const heap_node &b){ 26 return a.v > b.v; 27 } 28 29 int n, d[N], T; 30 int tot, first[N]; 31 bool vis[N]; 32 33 priority_queue <heap_node> h; 34 35 inline int read(){ 36 int x = 0, sgn = 1; 37 char ch = getchar(); 38 while (ch < '0' || ch > '9'){ 39 if (ch == '-') sgn = -1; 40 ch = getchar(); 41 } 42 while (ch >= '0' && ch <= '9'){ 43 x = x * 10 + ch - '0'; 44 ch = getchar(); 45 } 46 return sgn * x; 47 } 48 49 inline void add_edge(int x, int y, int z){ 50 e[++tot].next = first[x], first[x] = tot; 51 e[tot].to = y, e[tot].v = z; 52 } 53 54 inline void add_to_heap(const int p){ 55 for (int x = first[p]; x; x = e[x].next) 56 if (d[e[x].to] == inf){ 57 NODE.v = e[x].v + d[p], NODE.to = e[x].to; 58 h.push(NODE); 59 } 60 } 61 62 int Dijkstra(int S){ 63 int p; 64 for (p = 1; p <= T; ++p) d[p] = inf; 65 while (!h.empty()) h.pop(); 66 d[S] = 0, add_to_heap(S); 67 while (!h.empty()){ 68 if (d[h.top().to] != inf){ 69 h.pop(); 70 continue; 71 } 72 p = h.top().to; 73 d[p] = h.top().v; 74 h.pop(); 75 add_to_heap(p); 76 } 77 return d[T] == inf ? -1 : d[T]; 78 } 79 80 int main(){ 81 n = read(), T = read(); 82 int i, x, y; 83 for (i = 1; i <= T; ++i) 84 add_edge(i, i - 1, 0); 85 for (i = 1; i <= n; ++i){ 86 x = read(), y = read(); 87 add_edge(x - 1, y, 1); 88 } 89 printf("%d ", Dijkstra(0)); 90 return 0; 91 }
(p.s. Orz iwtwiioi 贪心什么的太神了)