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;
}

 

全部评论

相关推荐

2024-12-30 22:31
吉首大学 Web前端
工字钢写代码:改成吉林就OK了
点赞 评论 收藏
分享
双飞二本嵌入式求拷打我是在&nbsp;BOSS&nbsp;上投递的简历,好多都没人回复,这是开场白和简历求大神帮忙看看。您好!我是2025届应届生,最快可在一周内上岗,能够实习六个月以上,并接受加班。以下是我的核心优势和相关经验:1.&nbsp;嵌入式开发能力:&nbsp;&nbsp;&nbsp;熟练掌握STM32系列单片机及其外设(如GPIO、定时器、ADC、DAC、I2C、SPI、UART等),能够独立完成硬件驱动开发和调试。&nbsp;&nbsp;熟悉FreeRTOS实时操作系统,具备多任务调度和资源管理经验。&nbsp;&nbsp;熟悉LVGL图形库开发,能够实现嵌入式设备的图形界面设计。2.&nbsp;硬件设计能力:&nbsp;&nbsp;&nbsp;具备PCB设计经验,曾为2023年工创赛物流搬运赛道设计小车主板,带领团队获得国家级银奖。&nbsp;&nbsp;&nbsp;熟悉硬件原理图分析,能够快速理解并调试硬件电路。3.&nbsp;机器人开发与竞赛经验:&nbsp;&nbsp;&nbsp;在全国大学生智能车竞赛、ROS机器人竞赛中多次获得国家级奖项,具备丰富的机器人开发经验。&nbsp;&nbsp;&nbsp;熟悉Linux环境,对ROS和ROS&nbsp;2有一定了解,能够进行机器人系统的开发与调试。4.&nbsp;编程能力:&nbsp;&nbsp;&nbsp;熟悉C/C++,熟悉Python,能够高效完成嵌入式开发和算法实现。&nbsp;&nbsp;&nbsp;具备良好的代码规范和文档编写能力。5.&nbsp;团队协作与领导能力:&nbsp;&nbsp;&nbsp;在多个项目中担任核心开发或团队负责人,具备良好的沟通能力和团队协作精神。&nbsp;&nbsp;&nbsp;在工创赛中带领团队完成项目规划、任务分配和技术攻关,展现了较强的领导力。我对嵌入式开发、机器人技术和智能硬件充满热情,期待加入贵公司,与团队共同成长,为公司创造价值!如果有合适的岗位,欢迎随时联系我,期待进一步沟通!
沉淀一会:嵌入式就是狗屎
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务