线段树的几种写法
创始人
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<

 

相关内容

热门资讯

黑科技软件(德州线上扑克)Wp... 黑科技软件(德州线上扑克)Wpk往昔有挂!太夸张了都是是有挂(2023已更新)(哔哩哔哩);德州简单...
第三分钟了解!德州ai人工智能... 第三分钟了解!德州ai人工智能软件免费,熊猫游戏辅助器,透明教程(有挂技巧)-哔哩哔哩1、起透看视 ...
黑科技挂(aa扑克模拟器)来玩... 此外,数据分析德州(来玩德州)辅助神器app还具备辅助透视行为开挂功能,通过对客户来玩德州透明挂的深...
九分钟了解!wepoke透明黑... 九分钟了解!wepoke透明黑科技,全民牛牛拼三张辅助器免费,必胜教程(有挂存在)-哔哩哔哩;1、起...
黑科技肯定(来玩德州app)德... 1、黑科技肯定(来玩德州app)德州aapoker俱乐部确实真的有挂!太离谱了最初真的是有挂(202...
第1分钟了解!微扑克ai防封,... 第1分钟了解!微扑克ai防封,开心武汉花可以开挂吗,力荐教程(有挂详情)-哔哩哔哩运开心武汉花可以开...
黑科技ai代打(Wepoke大... 您好,拱趴大菠萝这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游...
第九分钟了解!微扑克ai代打,... 第九分钟了解!微扑克ai代打,德扑之星ai代打怎么弄,扑克教程(有挂规律)-哔哩哔哩1、操作简单,无...
黑科技线上(德州ai智能)aa... 黑科技线上(德州ai智能)aaPoker起初是真的有挂!太坑了果然有挂(2021已更新)(哔哩哔哩)...
八分钟了解!wepoke黑科技... 八分钟了解!wepoke黑科技靠谱吗,云龙逮杠麻将有挂吗,AA德州教程(有挂讲解)-哔哩哔哩;1、每...