A Simple Problem with Integers POJ - 3468 (线段树)
Posted fengzeng666
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了A Simple Problem with Integers POJ - 3468 (线段树)相关的知识,希望对你有一定的参考价值。
思路:线段树,区间更新,区间查找
1 #include<iostream> 2 #include<vector> 3 #include<string> 4 #include<cmath> 5 #include<set> 6 #include<algorithm> 7 #include<cstdio> 8 #include<map> 9 #include<cstring> 10 #include<list> 11 12 #define MAXSIZE 100010 13 14 using namespace std; 15 16 long long tree[4*MAXSIZE]; 17 long long lz[4*MAXSIZE]; 18 int N, Q; 19 20 void init() 21 22 memset(tree, 0, sizeof(tree)); 23 memset(lz, 0, sizeof(lz)); 24 25 26 void build(int node, int l, int r) 27 28 if(l == r) 29 30 scanf("%lld", &tree[node]); 31 return; 32 33 34 int mid = (l+r)/2; 35 build(node*2, l, mid); 36 build(node*2+1, mid+1, r); 37 38 tree[node] = tree[node*2] + tree[node*2+1]; 39 40 41 void push_down(int node, int l, int r) 42 43 if(lz[node]) 44 45 int mid = (l+r)/2; 46 lz[node*2] += lz[node]; 47 lz[node*2+1] += lz[node]; 48 tree[node*2] += (mid-l+1)*lz[node]; 49 tree[node*2+1] += (r-mid)*lz[node]; 50 lz[node] = 0; 51 52 53 54 void update_range(int node, int l, int r, int L, int R, int add) 55 56 if(l <= L && r >= R) 57 58 lz[node] += add; 59 tree[node] += (R-L+1)*add; 60 return; 61 62 push_down(node, L, R); 63 int mid = (L+R)/2; 64 if(mid >= l) 65 update_range(node*2, l, r, L, mid, add); 66 if(mid < r) 67 update_range(node*2+1, l, r, mid+1, R, add); 68 tree[node] = tree[node*2] + tree[node*2+1]; 69 70 71 long long query_range(int node, int l, int r, int L, int R) 72 73 if(l <= L && r >= R) 74 75 return tree[node]; 76 77 push_down(node, L, R); 78 int mid = (L+R)/2; 79 long long sum = 0; 80 if(mid >= l) 81 sum += query_range(node*2, l, r, L, mid); 82 if(mid < r) 83 sum += query_range(node*2+1, l, r, mid+1, R); 84 85 return sum; 86 87 88 89 90 int main() 91 92 scanf("%d%d", &N, &Q); 93 init(); 94 build(1, 1, N); 95 while(Q--) 96 97 char ch; 98 scanf(" %c", &ch); 99 if(ch == ‘Q‘) 100 101 int a, b; 102 scanf("%d%d", &a, &b); 103 printf("%lld\\n", query_range(1, a, b, 1, N)); 104 105 else if(ch == ‘C‘) 106 107 int a, b, c; 108 scanf("%d%d%d", &a, &b, &c); 109 update_range(1, a, b, 1, N, c); 110 111 112 113 114 return 0; 115
以上是关于A Simple Problem with Integers POJ - 3468 (线段树)的主要内容,如果未能解决你的问题,请参考以下文章
POJ3468A Simple Problem with Integers
线段树专题 POJ3468 A Simple Problem with Integers
A Simple Problem with Integers
A Simple Problem with Integers