尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

LGP3372 [LG TPLT] 线段树一 学习笔记

LGP3372 [LG TPLT] 线段树一 学习笔记
📅 发布时间:2026/6/19 9:38:21

LGP3372 [LG TPLT] 线段树·一 学习笔记

\(\texttt{Luogu Link}\)

题意简述

给你一个序列。

做法解析一

线段树。

维护若干个区间的信息,满足可以用 \(O(\log n)\) 个区间的信息拼起来整个区间的信息。所以它非常巧妙。还有巧妙的传 tag 机制。对,应该是。

我也不知道这里有必要写什么。先空着吧。

来都来了,测一下自己敲最基础的线段树的耗时。

代码实现一

好吧,我居然忘了区间加线段树在 maketag 的时候,sum[u]+=tag[u]*clen[u] 这个地方是有个 clen[u] 的系数的!见鬼。

#include <bits/stdc++.h>
using namespace std;
using namespace obasic;
const int MaxN=1e5+5;
int N,M,Opt,X,Y;lolo A[MaxN],Z;
struct SegTree{int cl[MaxN<<2],cr[MaxN<<2],cmid[MaxN<<2];lolo sum[MaxN<<2],tag[MaxN<<2];int ls(int u){return u<<1;}int rs(int u){return (u<<1)|1;}void pushup(int u){sum[u]=sum[ls(u)]+sum[rs(u)];}void build(int u,int l,int r){cl[u]=l,cr[u]=r;if(l==r){sum[u]=A[l];return;}int mid=(l+r)>>1;cmid[u]=mid;build(ls(u),l,mid),build(rs(u),mid+1,r),pushup(u);}void maketag(int u,lolo x){sum[u]+=(cr[u]-cl[u]+1)*x,tag[u]+=x;}void pushdown(int u){if(tag[u])maketag(ls(u),tag[u]),maketag(rs(u),tag[u]),tag[u]=0;}void modify(int u,int dl,int dr,lolo x){if(dl<=cl[u]&&cr[u]<=dr){maketag(u,x);return;}pushdown(u);if(dl<=cmid[u])modify(ls(u),dl,dr,x);if(dr>cmid[u])modify(rs(u),dl,dr,x);pushup(u);}lolo getsum(int u,int dl,int dr){if(dl<=cl[u]&&cr[u]<=dr)return sum[u];pushdown(u);lolo res=0;if(dl<=cmid[u])res+=getsum(ls(u),dl,dr);if(dr>cmid[u])res+=getsum(rs(u),dl,dr);return res;}
}SgT;
int main(){readis(N,M);for(int i=1;i<=N;i++)readi(A[i]);SgT.build(1,1,N);for(int i=1;i<=M;i++){readis(Opt,X,Y);if(Opt==1)readi(Z),SgT.modify(1,X,Y,Z);if(Opt==2)writil(SgT.getsum(1,X,Y));}return 0;
}

做法解析二

区间加区间修树状数组。

首先,修改或查询 \([l,r]\) 都差分成 \([1,r]\) 和 \([1,l)\) 解决。

考虑求出原数组的差分数组 \(B\)。区间修改在差分数组上表现为两个单点改;对于区间查询显然有:\(\sum_{i=1}^p a_i=\sum_{i=1}^p (p+1-i)\times b_i=(p+1) \sum_{i=1}^p b_i-\sum_{i=1}^p i\times b_i\)。所以我们维护 \(\sum_{i=1}^p b_i\) 和 \(\sum_{i=1}^p i\times b_i\)。

代码实现二

#include <bits/stdc++.h>
using namespace std;
using namespace obasic;
const int MaxN=1e5+5;
int N,M,Opt;lolo X,Y,Z;
struct BinidTree{int n;lolo ta[MaxN],ts[MaxN];void init(int x){n=x;fill(ta,ta+n+1,0),fill(ts,ts+n+1,0);}int lowbit(int x){return x&(-x);}void add(int p,lolo x){for(int q=p;q&&q<=n;q+=lowbit(q))ta[q]+=x,ts[q]+=p*x;}void adds(int l,int r,lolo x){add(l,x),add(r+1,-x);}lolo gts(int p){lolo res=0;for(int q=p;q;res+=(p+1)*ta[q]-ts[q],q-=lowbit(q));return res;}lolo getsum(int l,int r){return gts(r)-gts(l-1);}
}BiT;
int main(){readis(N,M);BiT.init(N);for(int i=1;i<=N;i++)readi(X),BiT.adds(i,i,X);for(int i=1;i<=M;i++){readis(Opt,X,Y);if(Opt==1)readi(Z),BiT.adds(X,Y,Z);if(Opt==2)writil(BiT.getsum(X,Y));}return 0;
}

反思总结

\(\sum_{i=1}^p (p+1-i)\times b_i=(p+1)\sum_{i=1}^p i-\sum_{i=1}^p b_i\times b_i\)。记好。

相关新闻

  • Day27 | Java集合框架之List接口详解 - 实践
  • jeecg vue2前端组件
  • 从Salesforce到国产CRM,纷享销客助力顺祥新材料提速提效

最新新闻

  • 2026苏州钻石回收实测|国标4C定级,全城无套路靠谱门店变现指南 - 薛定谔的梨花猫
  • C语言宽字符处理:wmemcmp、wmemcpy、wprintf核心函数详解与实战
  • 多模态大语言模型LISA
  • 2026长沙回收百达翡丽手表门店分级指南,一线标杆店铺评级,区分正规与小作坊 - 名奢变现站
  • 如何通过WeChatMsg实现微信聊天记录的本地化解析与数据主权保护?
  • 告别GUI开发噩梦:用Dear ImGui在30分钟内为C++项目添加专业界面

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号