2018年全国多校算法寒假训练营练习比赛(第五场)H Tree Recovery

                                                                                           Tree Recovery

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld

题目描述:进行区间求和,区间加减(线段树加懒惰标记)

输入

10 5
1 2 3 4 5 6 7 8 9 10
Q 4 4
Q 1 10
Q 2 4
C 3 6 3
Q 2 4

输出

4
55
9
15
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn = 100000+500;
long long a[maxn];
struct node
{
    long long l,r;
    long long date,add;
} T[maxn*4];
long long n,m;
long long ans=0;
void build(long long v,long long l,long long r)
{
    T[v].l=l,T[v].r=r;
    if(l==r)
    {
        T[v].date=a[l];
        return ;
    }
    long long mid = (l+r)>>1;
    build(v<<1,l,mid);
    build(v<<1|1,mid+1,r);
    T[v].date=T[v<<1].date+T[v<<1|1].date;
}
void add(long long v,long long l,long long r,long long value)
{
    T[v].date+=(r-l+1)*value;
    if(T[v].l==l&&T[v].r==r)
    {
        T[v].add+=value;
        return ;
    }
    if(T[v].add)
    {
        T[v<<1].date+=(T[v<<1].r-T[v<<1].l+1)*T[v].add;
        T[v<<1|1].date+=(T[v<<1|1].r-T[v<<1|1].l+1)*T[v].add;
        T[v<<1].add+=T[v].add;
        T[v<<1|1].add+=T[v].add;
        T[v].add=0;
    }
    long long mid=(T[v].l+T[v].r)>>1;
    if(r<=mid)
    {
        add(v<<1,l,r,value);
    }
    else
    {
        if(l>mid)
        {
            add(v<<1|1,l,r,value);
        }
        else
        {
            add(v<<1,l,mid,value);
            add(v<<1|1,mid+1,r,value);
        }
    }
}
void query(long long v,long long l,long long r)
{
    if(T[v].l==l&&T[v].r==r)
    {
        ans+=T[v].date;
        return ;
    }
    if(T[v].add)
    {
        T[v<<1].date+=(T[v<<1].r-T[v<<1].l+1)*T[v].add;
        T[v<<1|1].date+=(T[v<<1|1].r-T[v<<1|1].l+1)*T[v].add;
        T[v<<1].add+=T[v].add;
        T[v<<1|1].add+=T[v].add;
        T[v].add=0;
    }
    long long mid = (T[v].l+T[v].r)>>1;
    if(r<=mid)
    {
        query(v<<1,l,r);
    }
    else
    {
        if(l>mid)
            query(v<<1|1,l,r);
        else
        {
            query(v<<1,l,mid);
            query(v<<1|1,mid+1,r);
        }
    }
}
int main()
{
    scanf("%lld%lld",&n,&m);
    for(int i=1; i<=n; i++)scanf("%lld",&a[i]);
    build(1,1,n);
    while(m--)
    {
        char s[2];
        long long x,y,z;
        scanf("%s",s);
        if(s[0]=='Q')
        {
            scanf("%lld%lld",&x,&y);
            ans=0;
            query(1,x,y);
            printf("%lld\n",ans);
        }
        else
        {
            scanf("%lld%lld%lld",&x,&y,&z);
            add(1,x,y,z);
        }
    }
    return 0;
}

 

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
5652次浏览 53人参与
# 你的实习产出是真实的还是包装的? #
1171次浏览 29人参与
# 米连集团26产品管培生项目 #
4373次浏览 203人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
6964次浏览 37人参与
# 简历第一个项目做什么 #
31275次浏览 314人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
186406次浏览 1115人参与
# 巨人网络春招 #
11196次浏览 223人参与
# 研究所笔面经互助 #
118765次浏览 577人参与
# 面试紧张时你会有什么表现? #
30406次浏览 188人参与
# 简历中的项目经历要怎么写? #
309439次浏览 4157人参与
# AI时代,哪些岗位最容易被淘汰 #
62538次浏览 736人参与
# 网易游戏笔试 #
6329次浏览 83人参与
# 职能管理面试记录 #
10703次浏览 59人参与
# 把自己当AI,现在最消耗你token的问题是什么? #
6902次浏览 154人参与
# 从哪些方向判断这个offer值不值得去? #
56709次浏览 357人参与
# 你怎么看待AI面试 #
179317次浏览 1170人参与
# 腾讯音乐求职进展汇总 #
160406次浏览 1105人参与
# 小红书求职进展汇总 #
226861次浏览 1356人参与
# 正在春招的你,也参与了去年秋招吗? #
362594次浏览 2631人参与
# 你的房租占工资的比例是多少? #
92128次浏览 896人参与
# 校招笔试 #
466773次浏览 2952人参与
# 机械求职避坑tips #
94402次浏览 567人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务