zoukankan      html  css  js  c++  java
  • 线段树题单练习题解

    线段树题单练习题解

    题单

    1 hdu 1166

    #include <bits/stdc++.h>
    using namespace std;
    
    const int N = 	5e4+5;
    
    typedef long long ll;
    
    int t, n, p, a, b;
    char op[10];
    ll val;
    
    ll tree[N<<2];
    
    void push_up(int rt){
        tree[rt] = tree[rt<<1] + tree[rt<<1|1];
    }
    void build(int rt, int l, int r){
        if(l==r){
            scanf("%lld", &tree[rt]);
        }else{
            int mid = (l+r)>>1;
            build(rt<<1, l, mid);
            build(rt<<1|1, mid+1, r);
            push_up(rt);
        }
    }
    
    void modify(int rt, int l, int r, int p, ll v){
        tree[rt] += v;
        if(l==r) return;
        int mid = (l+r)>>1;
        if(p <= mid) modify(rt<<1, l, mid, p, v);
        else modify(rt<<1|1, mid+1, r, p, v);
        push_up(rt);
    }
    
    ll query(int rt, int l, int r, int ql, int qr){
        if(ql <= l && qr >= r){
            return tree[rt];
        }else{
            ll ans = 0;
            int mid = (l+r)>>1;
            if(ql <= mid){
                ans += query(rt<<1, l, mid, ql, qr);
            }
            if(qr > mid){
                ans += query(rt<<1|1, mid+1, r, ql, qr);
            }
            return ans;
        }
    }
    
    
    int main(){
        scanf("%d", &t);
        for(int _ = 1; _ <= t; ++_){
            printf("Case %d:
    ", _);
            scanf("%d", &n);
            build(1, 1, n);
            while (1) {
                getchar();
                scanf("%s", op);
                if(*op == 'Q'){
                    scanf("%d%d", &a, &b);
                    printf("%lld
    ", query(1, 1, n, a, b));
                }else if(*op == 'A'){
                    scanf("%d%lld", &p, &val);
                    modify(1, 1, n, p, val);
                }else if(*op == 'S'){
                    scanf("%d%lld", &p, &val);
                    modify(1, 1, n, p, -val);
                }else{
                    break;
                }
            }
        }
        
        return 0;
    }
    

    hdu 1754

    #include <bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    
    const int N = 2e5+5;
    
    int n, m, a, b, p;
    ll v;
    char op[10];
    ll arr[N];
    ll tree[N<<2];
    
    inline ll Max(ll a, ll b){
        return a>b?a:b;
    }
    
    void build(int rt, int l, int r){
        if(l==r){
            scanf("%lld", &tree[rt]);
        }else{
            int mid = l+r>>1;
            build(rt<<1, l, mid);
            build(rt<<1|1, mid+1, r);
            tree[rt] = Max(tree[rt<<1], tree[rt<<1|1]);
        }
    }
    
    void modify(int rt, int l, int r, int p, ll v){
        tree[rt] = Max(tree[rt], v);
        if(l==r)return;
        int mid = l+r>>1;
        if(p <= mid) modify(rt<<1, l, mid, p, v);
        else modify(rt<<1|1, mid+1, r, p, v);
    }
    
    ll query(int rt, int l, int r, int ql, int qr){
        if(ql <= l && qr >= r) return tree[rt];
        else{
            ll ans = 0;
            int mid = l+r>>1;
            if(ql <= mid){
                ans = query(rt<<1, l, mid, ql, qr);
            }
            if(qr > mid){
                ans = Max(ans, query(rt<<1|1, mid+1, r, ql, qr));
            }
            return ans;
        } 
    }
    
    
    int main(){
        while(scanf("%d%d", &n, &m) != EOF){
            build(1, 1, n);
            while(m--){
                getchar();
                scanf("%s", op);
                if(*op == 'Q'){
                    scanf("%d%d", &a, &b);
                    printf("%lld
    ", query(1, 1, n, a, b));
                }else{
                    scanf("%d%lld", &p, &v);
                    modify(1, 1, n, p, v);
                }
            }
        }
    
        return 0;
    }
    
    ---- suffer now and live the rest of your life as a champion ----
  • 相关阅读:
    计算几何
    HDU 4267
    HDU 4277
    NYOJ 123(插线问点)
    Set
    HDU 1792
    从文本文件读取数据到用vector实现的二维数组中
    为什么计算机采用二进制而不是八进制或者十六进制
    Google C++编程风格指南1
    编程中的命名设计
  • 原文地址:https://www.cnblogs.com/popodynasty/p/14759084.html
Copyright © 2011-2022 走看看