zoukankan      html  css  js  c++  java
  • 自用综合线段树模板(区间加乘、区间置数、区间求和)

    ll p,a[MAXN],atag[MAXN],mtag[MAXN],ctag[MAXN],tree[MAXN];
    
    void Pushup(int rt){tree[rt]=(tree[rt<<1]+tree[rt<<1|1])%p;}
    
    void Pushdown(int rt,int ln,int rn){
        if(ctag[rt]!=-1){
            ctag[rt<<1]=ctag[rt<<1|1]=ctag[rt];
            tree[rt<<1]=ctag[rt]*ln%p;
            tree[rt<<1|1]=ctag[rt]*rn%p;
            atag[rt<<1]=atag[rt<<1|1]=0;
            mtag[rt<<1]=mtag[rt<<1|1]=1;
            ctag[rt]=-1;
        }
        if(mtag[rt]!=1){
            mtag[rt<<1]=(mtag[rt<<1]*mtag[rt])%p;
            mtag[rt<<1|1]=(mtag[rt<<1|1]*mtag[rt])%p;
            atag[rt<<1]=(atag[rt<<1]*mtag[rt])%p;
            atag[rt<<1|1]=(atag[rt<<1|1]*mtag[rt])%p;
            tree[rt<<1]=(tree[rt<<1]*mtag[rt])%p;
            tree[rt<<1|1]=(tree[rt<<1|1]*mtag[rt])%p;
            mtag[rt]=1;
        }
        if(atag[rt]){
            atag[rt<<1]=(atag[rt<<1]+atag[rt])%p;
            atag[rt<<1|1]=(atag[rt<<1|1]+atag[rt])%p;
            tree[rt<<1]=(tree[rt<<1]+atag[rt]*ln)%p;
            tree[rt<<1|1]=(tree[rt<<1|1]+atag[rt]*rn)%p;
            atag[rt]=0;
        }
    }
    
    void Build(int l,int r,int rt){
        atag[rt]=0; ctag[rt]=-1; mtag[rt]=1;
        if(l==r){
            tree[rt]=a[l]%p;
            return ;
        }
        int mid=(l+r)/2;
        Build(ls);
        Build(rs);
        Pushup(rt);
    }
    
    void Add(int L,int R,int C,int l,int r,int rt){
        if(L<=l&&R>=r){
            tree[rt]=(tree[rt]+1ll*C*(r-l+1))%p;
            atag[rt]=(atag[rt]+C)%p;
            return ;
        }
        int mid=(l+r)/2;
        Pushdown(rt,mid-l+1,r-mid);
        if(L<=mid)Add(L,R,C,ls);
        if(R>mid)Add(L,R,C,rs);
        Pushup(rt);
    }
    
    void Mul(int L,int R,int C,int l,int r,int rt){
        if(L<=l&&R>=r){
            tree[rt]=tree[rt]*C%p;
            atag[rt]=atag[rt]*C%p;
            mtag[rt]=mtag[rt]*C%p;
            return ;
        }
        int mid=(l+r)/2;
        Pushdown(rt,mid-l+1,r-mid);
        if(L<=mid)Mul(L,R,C,ls);
        if(R>mid)Mul(L,R,C,rs);
        Pushup(rt);
    }
    
    
    void Change(int L,int R,int C,int l,int r,int rt){
        if(L<=l&&R>=r){
            tree[rt]=1ll*(r-l+1)*C%p;
            ctag[rt]=C%p;
            atag[rt]=0;
            mtag[rt]=1;
            return ;
        }
        int mid=(l+r)/2;
        Pushdown(rt,mid-l+1,r-mid);
        if(L<=mid)Change(L,R,C,ls);
        if(R>mid)Change(L,R,C,rs);
        Pushup(rt);
    }
    
    ll Query(int L,int R,int l,int r,int rt){
        if(L<=l&&R>=r)return tree[rt]%p;
        int mid=(l+r)/2;
        Pushdown(rt,mid-l+1,r-mid);
        ll ans=0;
        if(L<=mid)ans=(ans+Query(L,R,ls))%p;
        if(R>mid)ans=(ans+Query(L,R,rs))%p;
        return ans;
    }
  • 相关阅读:
    吃一堑长一智
    人做事 天看着
    【转贴】英语中12个月名称的由来
    4199,流氓中的流氓
    【转贴】看D片容易误解的10个词组
    【转载】中国小吃(英文表达)
    拼死拼活为了啥!
    GCII 1.4对1.31改进
    上古III的汉化和美化修正
    linux下tar的用法
  • 原文地址:https://www.cnblogs.com/Mmasker/p/12905461.html
Copyright © 2011-2022 走看看