Personal templates, tree arrays
The principle does not speak, only say the usage
After the tree array is established successfully, the incoming parameter i,j can be easily solved by the array a[i]+a[.] Value of +...+a[j]
The core function lowbit (), whether it is a tree-like array or an update, is the most important function of the function, but also the essence of reducing the complexity of time.
int lowbit (int x) { return x& (-X);}
The creation of a tree array is, in fact, an ongoing process of updating an element by increasing or decreasing it, passing in the parameter subscript and the value that you want to modify.
Sometimes, we want to update the value of a location to X directly, and when passing in the parameter, the change of value (int index, (X-a[index])) {} can achieve the desired effect.
void change (int index,int value) { while (index<=n) { t[index]+=value; Index+=lowbit (index);} }
All of the preceding operations are intended to pave the final query, which calculates the value from A[0] +....+a[x].
int sum (int x) { int ans = 0; while (x>0) { ans+=t[x]; X-=lowbit (x); } return ans;}
If you want to calculate the value of an interval, suppose to calculate the value from A[l] +....+a[r], I can do this function with some modification based on the SUM function, which is actually sum (R)-sum (L-1)
c State of the death of a country during the period of military exercises, so the C state spy chief Derek and his men tidy began to busy again. Country A has a line of N engineering camps along the coastline, and Derek and tidy are tasked with monitoring the activities of these engineering camps. As a result of the adoption of some advanced monitoring tools, the number of people in each engineering camp, C, is well-informed and the number of personnel in each engineering camp is likely to change, possibly by increasing or reducing the number of staff, but none of them can escape the surveillance of State C.
The CIA wants to study what tactics the enemy is practicing, so Tidy to report to Derek at any time about how many people there are in a succession of engineering camps, such as Derek asking: "Tidy, Report to the 3rd camp to the 10th camp." Tidy is about to start calculating the total number of people in this section and report it immediately. But the number of enemy barracks is constantly changing, and Derek Each asked the paragraph is not the same, so tidy had to every time a camp to count, quickly exhausted, Derek to tidy's calculation speed more and more dissatisfied: "You a dead Fat boy, calculate so slow, I fire you squid!" Tidy thought, "You can count on yourself, it's a tiring job!" I wish you would fire me! " Helpless under, tidy had to call computer experts windbreaker for help, Windbreaker said: "Die fat, you usually do more than a point of ACM and see more Algorithms book, now taste the bitter pill!" Tidy said: "I know the wrong ... "But Windbreaker already hung up the phone." Tidy is very distressed, so he really will collapse, smart Reader, can you write a program to help him finish the work? But if your program is not efficient enough, tidy will still be scolded by Derek.
input the first line of an integer t, indicating that there is a T group of data.
the first line of each group of data is a positive integer n (n<=50000), which indicates that the enemy has N engineering camps, followed by n positive integers, and the second positive integer AI represents the first AI individual (1<=ai<=50) in the field of the I barracks.
Next, there is one command in each line, with 4 forms of command:
(1) Add I j,i and J are positive integers, which indicates that the I camp increases J person (J not more than ten)
(2) Sub I J, I and J are positive integers, indicating that I camp Reduction J person (J not more than ten);
(3) Query I J, I and J are positive integers, i<=j, indicating the total number of persons who have been questioned on the first to the J camps;
(4) end indicates that the command is final at each set of data;
up to 40,000 commands per set of data
output to Group I data, first outputs "case I:" and carriage return,
for each query, output an integer and enter it to indicate the total number of people in the segment you are asking for, which remains within Int.
Sample Input
Sample Output
Case 1:63,359
#include <bits/stdc++.h>using namespace Std;const int maxn = 50010;int t[maxn*2],n;int lowbit (int x) {return x& ;(-X);} void change (int index,int value) {while (index<=n) {t[index]+=value; Index+=lowbit (index); }}int sum (int x) {int ans = 0; while (x>0) {ans+=t[x]; X-=lowbit (x); } return ans; int main () {int cases; scanf ("%d", &cases); for (int k=1;k<=cases;k++) {memset (t,0,sizeof (T)); scanf ("%d", &n); int t; for (int i=1;i<=n;i++) {scanf ("%d", &t); Change (i,t); } printf ("Case%d:\n", K); string S; while (cin>>s) {int l,r; if (s== "End") break; scanf ("%d%d", &l,&r); if (s== "Query") {printf ("%d\n", Sum (R)-sum (L-1)); } else if (s== "Add") {change (L,R); } else if (s== "Sub") {change (L,-R); } } }}
Tree-like array--kin