hdu 1166 敌兵布阵

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166

树状数组:

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<iostream>
 4 #include<algorithm>
 5 using namespace std;
 6 
 7 const int maxn = 50050;
 8 int n,T;
 9 int a[maxn];
10 int C[maxn];
11 int lowbit(int x){
12     return x&(-x);
13 }
14 int sum(int x){
15     int ret = 0;
16     while(x > 0){
17         ret += C[x];
18         x -= lowbit(x);
19     }
20     return ret;
21 }
22 void add(int x,int d){
23     while(x<=n){
24         C[x] += d;
25         x += lowbit(x);
26     }
27 } 
28 int main()
29 {
30     //if(freopen("input.txt","r",stdin)== NULL)  {printf("Error\n"); exit(0);}
31     cin>>T;
32     char ch[10];
33     for(int t=1;t<=T;t++){
34         cin>>n;
35         for(int i=1;i<=n;i++) scanf("%d",&a[i]);
36         memset(C,0,sizeof(C));
37         for(int i=1;i<=n;i++){
38             for(int j=i-lowbit(i)+1;j<=i;j++){
39                 C[i] += a[j];
40             }
41         }
42         printf("Case %d:\n",t);
43         scanf("%s",ch);    
44         while(strcmp(ch,"End")){
45             if(!strcmp(ch,"Query")){
46                 int a,b;
47                    scanf("%d%d",&a,&b);
48                    int ans = sum(b) - sum(a-1);
49                    printf("%d\n",ans);
50             }
51             else if(!strcmp(ch,"Add")){
52                 int a,b; 
53                 scanf("%d%d",&a,&b);
54                 add(a,b);
55             }
56             else if(!strcmp(ch,"Sub")){
57                 int a,b;
58                 scanf("%d%d",&a,&b);
59                 add(a,-b);
60             }
61             scanf("%s",ch);    
62         } 
63     }
64     
65 }
View Code

线段树:

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int maxn = 50050;

int tree[4*maxn];
int a[maxn];
int n,T;
char ch[10];

void build(int u,int l,int r){
    if(l == r){
        tree[u] = a[l];
        return;
    }
    int mid = (l + r)>>1; 
    build(2*u,l,mid);
    build(2*u+1,mid+1,r); 
    tree[u] = tree[2*u] + tree[2*u+1];
}
void update(int u,int l,int r,int goal,int num){
    if(l == r){
        tree[u] += num;
        return;
    }
    int mid = (l+r)/2;                      //printf("%d %d %d\n",l,r,mid);
    if(goal <= mid)     update(2*u,l,mid,goal,num);
    else                update(2*u+1,mid+1,r,goal,num);
    tree[u] = tree[2*u] + tree[2*u+1];  //printf("tree %d %d         %d %d         %d\n",u,tree[u] ,2*u,tree[2*u] ,tree[2*u+1]);
}
int query(int u,int l,int r,int tl,int tr){
    if(tl<=l && r<=tr){
        return tree[u];
    }
    int mid = (l + r)/2;
    if(tr <= mid)       return query(2*u,l,mid,tl,tr);  
    else if(tl > mid)   return query(2*u+1,mid+1,r,tl,tr);
    else                 return query(2*u,l,mid,tl,tr)+query(2*u+1,mid+1,r,tl,tr);
    
}
int main()
{
    //if(freopen("input.txt","r",stdin)== NULL)  {printf("Error\n"); exit(0);}
    cin>>T;
    for(int t=1;t<=T;t++){
        cin>>n;
        memset(tree,0,sizeof(tree));
        for(int i=1;i<=n;i++) cin>>a[i];  
        
        int tl,tr;
        build(1,1,n);
        printf("Case %d:\n",t);
        cin>>ch;
        while(strcmp(ch,"End")){
            if(!strcmp(ch,"Query")){
                   scanf("%d%d",&tl,&tr);
                   int ans = query(1,1,n,tl,tr);
                   printf("%d\n",ans);
            }
            else if(!strcmp(ch,"Add")){
                int a,b; 
                scanf("%d%d",&a,&b);
                update(1,1,n,a,b);
            }
            else if(!strcmp(ch,"Sub")){
                int a,b;
                scanf("%d%d",&a,&b);
                update(1,1,n,a,-b);
            }
           scanf("%s",ch);    
        }
    }
    return 0;
}
View Code

 

posted @ 2013-06-02 22:59  等待最好的两个人  阅读(142)  评论(0编辑  收藏  举报