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

 

相关内容

热门资讯

教程辅助“pokemmo手机脚... 教程辅助“pokemmo手机脚本”详细教程开挂辅助安装详细教程;无需打开直接搜索打开薇:136704...
透视代打“友友联盟免费辅助下载... 大家好,今天小编来为大家解答友友联盟免费辅助下载这个问题咨询软件客服可以免费测试直接加微信(1367...
教程辅助“aapoker脚本”... 您好:这款aapoker脚本游戏是可以开挂的,确实是有挂的,很多玩家在这款aapoker脚本游戏中打...
重大通报“闲逸辅助器下载”hh... 重大通报“闲逸辅助器下载”hhpoker可以控制吗(带开挂辅助脚本规律教程);打开点击测试直接进入微...
教程辅助“光明大厅微信呢链接辅... 教程辅助“光明大厅微信呢链接辅助试用”有挂教学开挂辅助工具规律教程1、下载安装好光明大厅微信呢链接辅...
每日必备“山西扣点免费辅助下载... 每日必备“山西扣点免费辅助下载”wejoker辅助软件视频(带开挂辅助脚本解密教程);亲,山西扣点免...
教程辅助“道游互娱辅助免费版”... 教程辅助“道游互娱辅助免费版”的确有挂开挂辅助器必胜教程道游互娱辅助免费版ai黑科技系统规律教程开挂...
玩家必看科普“桂麻圈辅助器使用... 玩家必看科普“桂麻圈辅助器使用方法”wepoker有透视吗(带开挂辅助下载详细教程!);亲,桂麻圈辅...
教程辅助“we poker辅助... 教程辅助“we poker辅助器”有挂头条开挂辅助插件详细教程1、下载安装好we poker辅助器,...
玩家科普“竹间穿有挂没”wep... 竹间穿有挂没是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信(...