码迷,mamicode.com
首页 > Web开发 > 详细

bzoj 1012 [JSOI2008]最大数maxnumber

时间:2015-05-24 23:23:00      阅读:159      评论:0      收藏:0      [点我收藏+]

标签:

原题链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1012 
线段树,单点更新。。

技术分享
 1 #include<algorithm>
 2 #include<iostream>
 3 #include<cstdlib>
 4 #include<cstdio>
 5 #define lc root<<1
 6 #define rc root<<1|1
 7 using std::max;
 8 const int Max_N = 200010;
 9 const int INF = 0x3f3f3f3f;
10 int MOD;
11 struct Node { int val; };
12 struct SegTree {
13     Node seg[Max_N << 2];
14     inline void push_up(int root) {
15         seg[root].val = max(seg[lc].val, seg[rc].val);
16     }
17     inline void update(int root, int l, int r, int pos, int t) {
18         if (pos > r || pos < l) return;
19         if (pos <= l && pos >= r) {
20             seg[root].val += t;
21             return;
22         }
23         int mid = (l + r) >> 1;
24         update(lc, l, mid, pos, t);
25         update(rc, mid + 1, r, pos, t);
26         push_up(root);
27     }
28     inline int query(int root, int l, int r, int x, int y) {
29         if (x > r || y < l) return -INF;
30         if (x <= l && y >= r) return seg[root].val;
31         int mid = (l + r) >> 1;
32         int v1 = query(lc, l, mid, x, y);
33         int v2 = query(rc, mid + 1, r, x, y);
34         return max(v1, v2);
35     }
36 }seg;
37 int main() {
38 #ifdef LOCAL
39     freopen("in.txt", "r", stdin);
40     freopen("out.txt", "w+", stdout);
41 #endif
42     char ch;
43     int n, v, res, len = 0;
44     while (~scanf("%d %d", &n, &MOD)) {
45         res = 0;
46         for (int i = 0; i < n; i++) {
47             getchar();
48             scanf("%c %d", &ch, &v);
49             if (ch == A) ++len, seg.update(1, 1, n, len, (res + v) % MOD);
50             else printf("%d\n", res = seg.query(1, 1, n, len - v + 1, n));
51         }
52     }
53     return 0;
54 }
View Code

 

bzoj 1012 [JSOI2008]最大数maxnumber

标签:

原文地址:http://www.cnblogs.com/GadyPu/p/4526576.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!