zoukankan      html  css  js  c++  java
  • 线段树区间修改区间查询模板(数据神坑)

    题目:

    对于一个数列,我们定义两种操作:
    A L R C – 在区间L至R上的所有数加上C
    B L R – 输出区间L到R上所有数的和
    为了简单起见,数列的初始值全都是0


    Input:

    输入有多组,处理到文件结束。
    对于每一组输出,第一行是三个整数N A B (1<=N<=1000000,1<=A<=N,A<=B<=N)
    接下来A行,每行三个数Li Ri Ci。(1<=Li<=N, Li<=Ri<=N, |Ci|<=100000000000000)。
    接下来B行,每行两个数 Li Ri。范围同上。


    Output:

    对于每一次查询,输出一行一个整数,表示查询结果。结果mod 1000000007。

    Sample Input:

    5 1 1
    1 3 1
    1 4

    Sample Output:

    3


    long long sumv[maxn*4],addv[maxn*4];
    long long a[maxn];
    void build(int o,int l,int r)
    {
        if( l == r) sumv[o] = a[l];
        else{
            int m  = l+(r-l)/2;
            build(o*2,l,m);
            build(o*2+1,m+1,r);
            sumv[o] = sumv[o*2] + sumv[o*2+1];
        } 
    }
    
    {
        build(1,1,n);//main函数中的调用
    }
    
    void pushup(int o)
    {
        sumv[o] = sumv[o*2]+sumv[o*2+1]; 
    }
    
    void pushdown(int o,int l ,int r)
    {
        if(addv[o])
        {
            addv[o*2] += addv[o];
            addv[o*2+1] +=  addv[o];
            int m  = l+(r-l)/2;
            sumv[o*2] += addv[o]*(m-l+1);
            sumv[o*2+1] += addv[o]*(r-m);
            addv[o] = 0;
         }
    } 
    
    void update(int o,int l,int r,int ql,int qr,long long add)
    {
        if(ql <= l && qr >= r)
        {
            addv[o] += add;
            sumv[o] += add*(r-l+1);
            return; 
        }    
        
        pushdown(o,l,r);
        int m = l+(r-l)/2;
        if(ql <= m) update(o*2,l,m,ql,qr,add);
        if(qr >= m+1) update(o*2+1,m+1,r,ql,qr,add);
        pushup(o);
    } 
    
    long long query(int o,int l,int r,int ql,int qr)
    {
        if(ql <= l && qr >= r) return sumv[o];
        pushdown(o,l,r);
        int m = l+(r-l)/2;
        long long ans =0;
        if(ql <= m) ans += query(o*2,l,m,ql,qr);
        if(qr >= m+1) ans += query(o*2+1,m+1,r,ql,qr);
        return ans;
    }

    针对这道题:

    1.long long sumv[maxn*4],addv[maxn*4];

     long long a[maxn];

     会ml

    2.两个大的int a,b相乘取模,要这样:

      ( (long long)a * (long long)b ) % MOD

      

  • 相关阅读:
    使用curl命令操作elasticsearch
    Elasticsearch + logstash + kibana 配置
    Solr6.2.0 + zookeeper 集群配置
    Elasticsearch + logstash中文指南
    ELK+kafka构建日志收集系统
    基于docker+etcd+confd + haproxy构建高可用、自发现的web服务
    mongodb配置
    Docker的私有仓库
    GitLab + Jenkins + Docker + Kubernetes。
    ansible 安装使用
  • 原文地址:https://www.cnblogs.com/inerbornthisway/p/7895541.html
Copyright © 2011-2022 走看看