0分求调,样例输出11 8 16

P3372 【模板】线段树 1

gengyan @ 2024-11-08 23:57:33

#include<bits/stdc++.h>
#define ll long long
#define MAXN 500010
using namespace std;
ll a[500010];
ll n, m;
struct segement_tree{
    struct node{
        ll l, r, sum, lazy = 0;
    } tree[4 * MAXN]; //线段树
    void build(ll i,ll l,ll r)
    {
        tree[i].l = l;
        tree[i].r = r;
        if(l==r){
            tree[i].sum = a[l];
            return;
        }
        ll mid = (l + r) >> 1;
        build(i << 1, l, mid);
        build(i << 1 | 1, mid + 1, r);
        tree[i].sum = tree[i << 1].sum + tree[i << 1 | 1].sum;
    }
    void pushdown(ll i){
        if(tree[i].lazy!=0){
            tree[i<<1].lazy += tree[i].lazy;
            tree[i<<1|1].lazy += tree[i].lazy;
            tree[i<<1].sum += (tree[i<<1].r - tree[i<<1].l + 1) * tree[i].lazy;
            tree[i << 1 | 1].sum += (tree[i << 1 | 1].r - tree[i << 1 | 1].l + 1) * tree[i].lazy;
            tree[i].lazy = 0;
        }
        return;
    }
    ll sec_search(ll i,ll l,ll r){
        if(tree[i].l>=l&&tree[i].r<=r)
            return tree[i].sum;
        if(tree[i].l>r||tree[i].r<l)
            return 0;
        pushdown(i);
        ll s = 0;
        if(tree[i<<1].r>=l)
            s += sec_search(i << 1, l, r);
        if(tree[i<<1|1].l<=r)
            s += sec_search(i << 1 | 1, l, r);
        return s;
    }
    void pt_modify(ll i,ll x,ll k){
        if(tree[i].l==tree[i].r){
            tree[i].sum += k;
            return;
        }
        if(tree[i<<1].r>=x)
            pt_modify(i << 1, x, k);
        else
            pt_modify(i << 1 | 1, x, k);
        tree[i].sum = tree[i << 1].sum + tree[i << 1 | 1].sum;
    }
    void sec_modify(ll i,ll l,ll r,ll k){
        if(tree[i].l>=l&&tree[i].r<=r){
            tree[i].sum += (tree[i].r - tree[i].l + 1) * k;
            tree[i].lazy += k;
            return;
        }
        pushdown(i);
        if(tree[i<<1].r>=l)
            sec_modify(i << 1, l, r, k);
        if(tree[i<<1|1].l<=r)
            sec_modify(i << 1|1, l, r, k);
    }
    ll pt_search(ll i,ll x){
        if(tree[i].l==tree[i].r)
            return tree[i].sum;
        pushdown(i);
        if(tree[i<<1].r>=x)
            return pt_search(i << 1, x);
        else
            return pt_search(i << 1 | 1, x);
    }
} st;
int main(){
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cin>>n>>m;
    for (int i = 1; i <= n;i++)
        cin >> a[i];
    st.build(1, 1, n);
    for (int i = 0; i < m;i++){
        ll p, x, y, k;
        cin >> p;
        if(p==1){
            cin >> x >> y >> k;
            st.sec_modify(1, x, y, k);
        }
        else{
            cin >> x >> y;
            cout << st.sec_search(1, x, y) << '\n';
        }
    }
    return 0;
}

by Michael1234 @ 2024-11-09 08:44:45

《修改不打pushup》

void sec_modify(ll i,ll l,ll r,ll k){
        if(tree[i].l>=l&&tree[i].r<=r){
            tree[i].sum += (tree[i].r - tree[i].l + 1) * k;
            tree[i].lazy += k;
            return;
        }
        pushdown(i);
        if(tree[i<<1].r>=l)
            sec_modify(i << 1, l, r, k);
        if(tree[i<<1|1].l<=r)
            sec_modify(i << 1|1, l, r, k);
        tree[i].sum=tree[i<<1].sum+tree[i<<1|1].sum;
    }

by gengyan @ 2024-11-09 11:21:28

@Michael1234 过了,%%%


|