线段树的几种写法
创始人
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辅助器,wepoker智能辅助插件(脚本)专业教程(好像真的是有挂)-哔哩哔...
一直以来!aapoker脚本,... 一直以来!aapoker脚本,aapoker辅助插件工具(透视)指南教程(其实真的是有挂)-哔哩哔哩...
透视揭幕!wpk辅助购买(透视... 透视揭幕!wpk辅助购买(透视)wpk显示有透视,教程窍要(有挂教程)-哔哩哔哩1、该软件可以轻松地...
透视练习!wepokerplu... 透视练习!wepokerplus外挂,wepoker有透视底牌吗(脚本)分享教程(果然有挂)-哔哩哔...
为了进一步!aapoker脚本... 为了进一步!aapoker脚本怎么用,aapoker破解侠是真的吗(透视)手册教程(原来存在有挂)-...
透视详情!如何判断wpk辅助软... 透视详情!如何判断wpk辅助软件的真假(透视)wpk真吗,教程诀窍(新版有挂)-哔哩哔哩1、完成如何...
透视教程书!wepoker怎么... 透视教程书!wepoker怎么看牌型,wepoker安装教程(脚本)有挂教程(确实是真的挂)-哔哩哔...
事发当天!aapoker辅助器... 您好,aapoker辅助器是真的吗这款游戏可以开挂的,确实是有挂的,需要了解加去威信【4852750...
透视解迷!wpk辅助哪里买(透... 透视解迷!wpk辅助哪里买(透视)wpk俱乐部是真的吗,教程积累(有挂讲解)-哔哩哔哩1、用户打开应...
透视绝活儿!wepoker免费... 透视绝活儿!wepoker免费透视脚本,wepoker辅助器怎么弄(脚本)透视教程(其实是有挂)-哔...