线段树

参考:线段树

模板题:线段树模板

写线段树需要注意的几点:

  1. build和update的时候最后记得加和!(d[p]=d[p<<1]+d[p<<1|1])
  2. lazy标记下传后记得把父节点的清除!(laz[p]=0)

变量

const int maxn=1e5+5;
int d[maxn<<2],a[maxn],laz[maxn<<2];
    /*d[]保存区间和 a[]保存原始数据 laz[]懒惰标记为*/

建树

void build(int s,int t,int p)
{
    if(s==t)
    {
        d[p]=a[s];
        return ;
    }
    int m=(s+t)>>1;
    build(s,m,p<<1),build(m+1,t,p<<1|1);
    d[p]=d[p<<1]+d[p<<1|1];
}

下传懒惰标记

void pushdown(int s,int t,int p)
{
    int m=(s+t)>>1;
    d[p<<1]+=laz[p]*(m-s+1),d[p<<1|1]+=laz[p]*(t-m);
    laz[p<<1]+=laz[p],laz[p<<1|1]+=laz[p];
    laz[p]=0;
}

单点更新

void update(int x,int s,int t,int k,int p)
{
    if(s==t)
    {
        d[p]+=k;return ;
    }
    int m=(s+t)>>1;
    if(x<=m) update(x,s,m,k,lson);
    else update(x,m+1,t,k,rson);
    d[p]=d[lson]+d[rson];
}

区间更新

void update(int l,int r,int c,int s,int t,int p)
{
    if(l<=s&&t<=r)
    {
        d[p]+=(t-s+1)*c,laz[p]+=c;
        return ;
    }
    int m=(s+t)>>1;
    if(laz[p]) pushdown(s,t,p);
    if(l<=m) update(l,r,c,s,m,p<<1);
    if(r>m) update(l,r,c,m+1,t,p<<1|1);
    d[p]=d[p<<1]+d[p<<1|1];
}

区间求和

int getsum(int l,int r,int s,int t,int p)
{
    if(l<=s&&t<=r) return d[p];
    int m=(s+t)>>1;
    if(laz[p]) pushdown(s,t,p);
    int sum=0;
    if(l<=m) sum+=getsum(l,r,s,m,p<<1);
    if(r>m) sum+=getsum(l,r,m+1,t,p<<1|1);
    return sum;
}
全部评论

相关推荐

秋招进行到现在终于能写总结了。完全没想到战线会拉这么长,过程会如此狼狈,不过更应该怪自己太菜了。好在所有的运气都用在了最后,也是有个去处。背景:双2本硕科班,无竞赛,本科一段研究所实习,硕士一段大厂暑期实习但无转正。技术栈是C++&nbsp;&amp;&nbsp;Golang,实习是客户端音视频(而且是鸿蒙端开发),简历两个C++项目一个Golang项目。主要投递岗位:后端,cpp软开,游戏服务端,测开,以及一些不拘泥于Java的岗位。从8月起总共投递123家公司,笔试数不清了,约面大约30家。offer/oc/意向:友塔游戏(第一个offer,面试体验很好,就是给钱好少南瑞继保(计算机科班点击就送(限男生),不...
乡土丁真真:佬很厉害,羡慕~虽然我还没有到校招的时候,也想讲一下自己的看法:我觉得不是CPP的问题,佬的背书双2,技术栈加了GO,有两段实习。投了123,面了30.拿到11个offer。这个数据已经很耀眼了。这不也是CPP带来的吗?当然也不止是CPP。至少来说在这个方向努力过的也会有好的结果和选择。同等学历和项目选java就会有更好的吗?我个人持疑问态度。当然CPP在方向选择上确实让人头大,但是我觉得能上岸,至于最后做什么方向,在我看来并不重要。至于CPP特殊,有岗位方向的随机性,java不是不挑方向,只是没得选而已。也希望自己以后校招的时候能offer满满
点赞 评论 收藏
分享
11-26 22:34
已编辑
重庆邮电大学 Java
快手 客户端开发 (n+5)k*16 公积金12
牛客895077908号:佬 什么双非硕啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务