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

 

相关内容

热门资讯

科技新动态!开心跑得快有辅助工... 科技新动态!开心跑得快有辅助工具吗(透明挂)外挂透明挂辅助神器(2021已更新)(哔哩哔哩)1)开心...
4分钟实锤!吉祥麻将,微扑克切... 4分钟实锤!吉祥麻将,微扑克切实是真的有挂,介绍教程(有挂揭秘);一、吉祥麻将AI软件牌型概率发牌机...
实测发现!鄂州晃晃外 挂(透视... 实测发现!鄂州晃晃外 挂(透视)透视辅助工具(2021已更新)(哔哩哔哩)1、鄂州晃晃外 挂系统规律...
三分钟了解!好彩麻将怎样才可以... 三分钟了解!好彩麻将怎样才可以拿好牌(透视辅助)外挂透明挂辅助机制(2020已更新)(哔哩哔哩)1、...
九分钟辅助!斗棋辅助器在哪,w... 九分钟辅助!斗棋辅助器在哪,wepoker本来真的是有挂,教你攻略(有挂教程)1、下载好斗棋辅助器在...
记者揭秘!!广东雀神麻雀辅助器... 记者揭秘!!广东雀神麻雀辅助器在哪里下载(透视)透视辅助app(2020已更新)(哔哩哔哩)1、很好...
终于清楚!皮皮跑胡子输赢规律(... 终于清楚!皮皮跑胡子输赢规律(辅助挂)外挂透明挂辅助机制(2026已更新)(哔哩哔哩)1)皮皮跑胡子...
二分钟科普!花城牌舍系统规律,... 二分钟科普!花城牌舍系统规律,aAPOKER竟然存在有挂,揭秘教程(有挂插件)进入游戏-大厅左侧-新...
一分钟教你!心悦手机麻将辅牌器... 一分钟教你!心悦手机麻将辅牌器(透视辅助)外挂透视辅助挂(2024已更新)(哔哩哔哩)1、每一步都需...
科技新动态!四方河南麻将赢牌技... 科技新动态!四方河南麻将赢牌技巧(透视)外挂透明挂辅助神器(2026已更新)(哔哩哔哩)1、每一步都...