思维+multiset ZOJ Monthly, July 2015 - H Twelves Monkeys
生活随笔
收集整理的這篇文章主要介紹了
思维+multiset ZOJ Monthly, July 2015 - H Twelves Monkeys
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
?
題目傳送門
1 /* 2 題意:n個時刻點,m次時光穿梭,告訴的起點和終點,q次詢問,每次詢問t時刻t之前有多少時刻點是可以通過兩種不同的路徑到達 3 思維:對于當前p時間,從現在到未來穿越到過去的是有效的值,排個序,從大到小詢問,那么之前添加的穿越點都是有效的, 4 用multiset保存。比賽時想到了排序,但是無法用線段樹實現查詢,stl大法好! 5 */ 6 #include <cstdio> 7 #include <algorithm> 8 #include <cstring> 9 #include <set> 10 #include <iostream> 11 using namespace std; 12 13 const int MAXN = 1e5 + 10; 14 const int INF = 0x3f3f3f3f; 15 struct Year { 16 int u, v; 17 bool operator < (const Year &r) const { 18 return u > r.u; 19 } 20 }y[MAXN]; 21 struct Query { 22 int p, id; 23 bool operator < (const Query &r) const { 24 return p > r.p; 25 } 26 }q[MAXN]; 27 int ans[MAXN]; 28 int a[3]; 29 int n, m, l; 30 31 int main(void) { //ZOJ Monthly, July 2015 - H Twelves Monkeys 32 //freopen ("H.in", "r", stdin); 33 34 while (scanf ("%d%d%d", &n, &m, &l) == 3) { 35 for (int i=1; i<=m; ++i) { 36 scanf ("%d%d", &y[i].u, &y[i].v); 37 } 38 for (int i=1; i<=l; ++i) { 39 scanf ("%d", &q[i].p); q[i].id = i; 40 } 41 42 sort (y+1, y+1+m); sort (q+1, q+1+l); 43 multiset<int> S; int j = 1; 44 for (int i=1; i<=l; ++i) { 45 while (j <= m && y[j].u >= q[i].p) { 46 S.insert (y[j].v); j++; 47 } 48 multiset<int>::iterator it; int cnt = 0; 49 for (it=S.begin (); it!=S.end (); ++it) { 50 a[++cnt] = *(it); if (cnt == 2) break; 51 } 52 if (cnt == 2 && a[2] <= q[i].p) ans[q[i].id] = q[i].p - a[2]; 53 else ans[q[i].id] = 0; 54 } 55 for (int i=1; i<=l; ++i) 56 printf ("%d\n", ans[i]); 57 } 58 59 return 0; 60 }?
轉載于:https://www.cnblogs.com/Running-Time/p/4680331.html
總結
以上是生活随笔為你收集整理的思维+multiset ZOJ Monthly, July 2015 - H Twelves Monkeys的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 那些年的那些事CISC和RISC发展中的
- 下一篇: Table 'barfoo_datace