线段树的几种写法
创始人
2024-11-15 02:32:59
0

1.运用结构体

// 结构体版 #include  #include  #include  using namespace std;  #define N 100005 #define LL long long #define lc u<<1 #define rc u<<1|1 LL w[N]; struct Tree{ //线段树   LL l,r,sum,add; }tr[N*4];  void pushup(LL u){ //上传   tr[u].sum=tr[lc].sum+tr[rc].sum; } void pushdown(LL u){ //下传   if(tr[u].add){     tr[lc].sum+=tr[u].add*(tr[lc].r-tr[lc].l+1),     tr[rc].sum+=tr[u].add*(tr[rc].r-tr[rc].l+1),     tr[lc].add+=tr[u].add,     tr[rc].add+=tr[u].add,     tr[u].add=0;         } } void build(LL u,LL l,LL r){ //建树   tr[u]={l,r,w[l],0};   if(l==r) return;   LL m=l+r>>1;   build(lc,l,m);   build(rc,m+1,r);   pushup(u); } void change(LL u,LL l,LL r,LL k){ //区修   if(l<=tr[u].l&&tr[u].r<=r){     tr[u].sum+=(tr[u].r-tr[u].l+1)*k;     tr[u].add+=k;     return;   }   LL m=tr[u].l+tr[u].r>>1;   pushdown(u);   if(l<=m) change(lc,l,r,k);   if(r>m) change(rc,l,r,k);   pushup(u); } LL query(LL u,LL l,LL r){ //区查   if(l<=tr[u].l && tr[u].r<=r) return tr[u].sum;   LL m=tr[u].l+tr[u].r>>1;   pushdown(u);   LL sum=0;   if(l<=m) sum+=query(lc,l,r);   if(r>m) sum+=query(rc,l,r);   return sum; } int main(){   int n,m,op,x,y,k;     cin>>n>>m;   for(int i=1; i<=n; i ++) cin>>w[i];      build(1,1,n);   while(m--){     cin>>op>>x>>y;     if(op==2)cout<>k,change(1,x,y,k);   }   return 0; }

2.数组版

// 数组版 #include  #include  #include  using namespace std;  #define N 100005 #define LL long long #define lc u<<1 #define rc u<<1|1 LL w[N]; LL sum[N*4],add[N*4]; //区间和,懒标记  void pushup(LL u){   sum[u]=sum[lc]+sum[rc]; } void pushdown(LL u,LL l,LL r,LL mid){   if(add[u]){     sum[lc]+=add[u]*(mid-l+1);     sum[rc]+=add[u]*(r-mid);     add[lc]+=add[u];     add[rc]+=add[u];     add[u]=0;   } } void build(LL u,LL l,LL r){   sum[u]=w[l];   if(l==r) return;   LL mid=l+r>>1;   build(lc,l,mid);    build(rc,mid+1,r);   pushup(u); } void change(LL u,LL l,LL r,LL x,LL y,LL k){ //区修   if(x>r || y>1;   pushdown(u,l,r,mid);       change(lc,l,mid,x,y,k); //裂开   change(rc,mid+1,r,x,y,k);   pushup(u); } LL query(LL u,LL l,LL r,LL x,LL y){ //区查   if(x>r || y>1;   pushdown(u,l,r,mid);   return query(lc,l,mid,x,y)+query(rc,mid+1,r,x,y); } int main(){   int n,m,op,x,y,k;     cin>>n>>m;   for(int i=1; i<=n; i ++) cin>>w[i];      build(1,1,n);   while(m--){     cin>>op>>x>>y;     if(op==1) cin>>k,change(1,1,n,x,y,k);     else cout<

 

相关内容

热门资讯

透视中牌率!wepoker免费... 透视中牌率!wepoker免费脚本咨询(透视)总是真的有辅助工具(真实有挂)-哔哩哔哩1、首先打开w...
外挂项目!德州透视是真的假的,... 外挂项目!德州透视是真的假的,聚星ai辅助工具激活码-切实一直都是有辅助攻略(哔哩哔哩)聚星ai辅助...
最新技巧!wpk俱乐部有没有辅... 您好,海贝之城有辅助吗这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩...
透视总结!wepoker有没有... 透视总结!wepoker有没有挂(透视)本来有辅助修改器(有挂教学)-哔哩哔哩1、这是跨平台的wep...
揭秘!wepoker私人局俱乐... 揭秘!wepoker私人局俱乐部怎么进,龙岩优优辅助,都是真的有辅助下载(的确有挂)1、龙岩优优辅助...
外挂经验!agpoker辅助,... 外挂经验!agpoker辅助,werplan辅助软件-好像有辅助方法(哔哩哔哩)1、下载好werpl...
做出回应!拱趴大菠萝辅助神器(... 做出回应!拱趴大菠萝辅助神器(透视)都是真的是有辅助下载(有挂辅助)-哔哩哔哩1、拱趴大菠萝辅助神器...
分享一款!wpk模拟器是什么,... 分享一款!wpk模拟器是什么,pokemmo辅助工具,其实真的是有辅助开挂(有挂分析)1、不需要AI...
外挂办法!智星菠萝德州辅助译码... 外挂办法!智星菠萝德州辅助译码插件靠谱吗,约局吧德州透视-本来一直都是有辅助工具(哔哩哔哩)1、每一...
透视辅助!哈糖大菠萝免费辅助器... 透视辅助!哈糖大菠萝免费辅助器(透视)都是有辅助辅助器(有挂实锤)-哔哩哔哩1、下载好哈糖大菠萝免费...