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

 

相关内容

热门资讯

七分钟了解!拱趴游戏辅助,福建... 七分钟了解!拱趴游戏辅助,福建兄弟十三水辅助器下载(原来是真的有挂)1、操作简单,无需注册,只需要使...
透视辅助!佛手大菠萝13道挂哪... 透视辅助!佛手大菠萝13道挂哪里(透视)永久脚本辅助器(详细辅助教你教程);1、佛手大菠萝13道挂哪...
透视智能ai"aa ... 透视智能ai"aa poker辅助"详细辅助靠谱教程(都是真的是有挂)1、点击下载安装,aa pok...
第六分钟了解!卡五星游戏源码,... 第六分钟了解!卡五星游戏源码,闲逸透视app真的可以透视吗(都是有挂)1、进入游戏-大厅左侧-新手福...
透视插件!拱趴大菠萝挂怎么安装... 透视插件!拱趴大菠萝挂怎么安装(透视)永久脚本辅助助手(详细辅助力荐教程);1、进入游戏-大厅左侧-...
透视透视"哈糖大菠萝... 透视透视"哈糖大菠萝挂法"详细辅助新版2025教程(其实是真的有挂)1、进入游戏-大厅左侧-新手福利...
第二分钟了解!新海贝之城辅助,... 第二分钟了解!新海贝之城辅助,打哈儿辅助(竟然真的是有挂)一、新海贝之城辅助AI软件牌型概率发牌机制...
透视脚本!hhpoker辅助挂... 透视脚本!hhpoker辅助挂下载(透视)永久脚本辅助app(详细辅助揭秘教程);1、下载好hhpo...
透视黑科技"wepo... 透视黑科技"wepoker透视器免费"详细辅助切实教程(都是存在有挂)小薇(透视辅助)致您一封信;亲...
第五分钟了解!多乐跑辅助,山西... 第五分钟了解!多乐跑辅助,山西扣点免费辅助(原来存在有挂)1、山西扣点免费辅助系统规律教程、山西扣点...