P6242-[模板]线段树3【吉司机线段树】

正题

题目链接:https://www.luogu.com.cn/problem/P6242


题目大意

给出一个长度为nnn的序列aaammm次要求支持操作

  1. 区间加上一个值kkk
  2. 区间所有aia_iai变为min{ai,k}min\{a_i,k\}min{ai,k}
  3. 区间求和
  4. 区间求最大值
  5. 区间求历史最大值

1≤n,q≤5×1051\leq n,q\leq 5\times 10^51n,q5×105


解题思路

额让我们来看看都有些什么操作,区间加权,区间取min…

欸好像到区间取min就不会了,这时候就要请出我们的吉司机线段树了。

吉司机线段树的原理大概就是一个节点处多维护一个与有关的值,这样我们一次修改时就只需要以常数的代价减少线段树的来达到均摊复杂度的效果。

先考虑这题的一个弱化版,要求支持

  • 区间求和
  • 区间求min
  • 区间取min

此时我们可以将线段树的势视为一个区间的不同数个数,那么我们需要找到一种新的标记方法使得我们能够减少一点势能。

而对于区间取min,要求在标记改变一个数的情况下能维护区间和,显然的区间取min第一个改变的肯定是最大值,所以此时我们就可以对于一个位置多维护三个值:区间最大值mx区间最大值个数t区间次大值se

此时我们修改时如果取min的值kkk分为以下情况

  • k≥mxk\geq mxkmx,此时不会对区间产生影响,势能不变。
  • mx>k>semx>k>semx>k>se,此时我们暴力修改mxmxmxttt,并以此修改sumsumsum,势能不变。
  • k≥sek\geq sekse,此时我们暴力递归左右两边修改,此时我们相当于多做了一次操作,但是mxmxmx变为了sesese相等的值,势能减一。

综上,由于初始序列的势能最大为O(n)O(n)O(n),这样的时间复杂度为O(nlog⁡n)O(n\log n)O(nlogn)

然后我们又多了一个操作

  • 区间加上取值kkk

注意到这个操作最多会修改log⁡n\log nlogn个区间,而每个被修改的区间都会产生多一个势能,时间复杂度就变为了O(nlog⁡2n)O(n\log^2n )O(nlog2n),不是很优秀,我们考虑更好的办法。

我们考虑分裂最大值的标记和次大值的标记,也就是我们的标记不再是区间减去的值,我们分裂为两个标记:区间最大值要减去的值lazyx区间非最大值要减去的值lazy

此时我们进行区间下传的时候非最大值的子区间就顺便处理了,如果两边都是最大值的子区间那么两边的势能都会减1,所以时间复杂度依旧是:O(nlog⁡n)O(n\log n)O(nlogn)

然后注意到这题还有一个难点

  • 区间查询历史最大值

先考虑正常的线段树是如何处理这种情况的,我们可以多维护两个东西:历史最大值b上次更新后历史最大标记lazyb,下传时我们用lazylazylazy更新lazyblazyblazyb,再用w+lazybw+lazybw+lazyb更新bbb就好了。

那么同样的我们在上面套一个类似吉司机线段树的东西,维护两种标记:上次更新后最大值的最大减少值lazyxb上次更新后非最大值的最大减少值lazyb

然后用类似的方法维护就好了。

写起来超级麻烦

时间复杂度:O((m+n)log⁡n)O((m+n)\log n)O((m+n)logn)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=5e5+10,M=N<<2,inf=1e18;
ll n,m,sum[M],mxa[M],mxb[M],se[M],t[M];
ll la[M],lax[M],lb[M],lbx[M];
void Merge(ll x,ll L,ll R){sum[x]=sum[x*2]+sum[x*2+1];mxa[x]=max(mxa[x*2],mxa[x*2+1]);mxb[x]=max(mxb[x*2],mxb[x*2+1]);if(mxa[x*2]==mxa[x*2+1]){t[x]=t[x*2]+t[x*2+1];se[x]=max(se[x*2],se[x*2+1]);}else if(mxa[x*2]<mxa[x*2+1]){t[x]=t[x*2+1];se[x]=max(mxa[x*2],se[x*2+1]);}else if(mxa[x*2]>mxa[x*2+1]){t[x]=t[x*2];se[x]=max(se[x*2],mxa[x*2+1]);}return;
}
void Updata(ll x,ll len,ll a,ll b,ll c,ll d){//a:非最大值加的值 b:最大值加的值 sum[x]+=a*(len-t[x])+b*t[x];mxb[x]=max(mxb[x],mxa[x]+d);lbx[x]=max(lbx[x],lax[x]+d);lb[x]=max(lb[x],la[x]+c);mxa[x]+=b;lax[x]+=b;la[x]+=a;if(se[x]!=-inf)se[x]+=a;
}
void Downdata(ll x,ll L,ll R){ll mid=(L+R)>>1,maxn=max(mxa[x*2],mxa[x*2+1]);if(mxa[x*2]==maxn)Updata(x*2,mid-L+1,la[x],lax[x],lb[x],lbx[x]);elseUpdata(x*2,mid-L+1,la[x],la[x],lb[x],lb[x]);if(mxa[x*2+1]==maxn)Updata(x*2+1,R-mid,la[x],lax[x],lb[x],lbx[x]);elseUpdata(x*2+1,R-mid,la[x],la[x],lb[x],lb[x]);la[x]=lax[x]=lb[x]=lbx[x]=0;return;
}
void ChangeAdd(ll x,ll L,ll R,ll l,ll r,ll val){if(L==l&&R==r){Updata(x,R-L+1,val,val,val,val);return;}ll mid=(L+R)>>1;Downdata(x,L,R);if(r<=mid)ChangeAdd(x*2,L,mid,l,r,val);else if(l>mid)ChangeAdd(x*2+1,mid+1,R,l,r,val);else ChangeAdd(x*2,L,mid,l,mid,val),ChangeAdd(x*2+1,mid+1,R,mid+1,r,val);Merge(x,L,R);return;
}
void ChangeMin(ll x,ll L,ll R,ll l,ll r,ll val){ll mid=(L+R)>>1;if(val>=mxa[x])return;if(L==l&&R==r){if(val>se[x]){Updata(x,R-L+1,0,val-mxa[x],0,val-mxa[x]);return;}Downdata(x,L,R);ChangeMin(x*2,L,mid,l,mid,val);ChangeMin(x*2+1,mid+1,R,mid+1,r,val);Merge(x,L,R);return;}Downdata(x,L,R);if(r<=mid)ChangeMin(x*2,L,mid,l,r,val);else if(l>mid)ChangeMin(x*2+1,mid+1,R,l,r,val);else ChangeMin(x*2,L,mid,l,mid,val),ChangeMin(x*2+1,mid+1,R,mid+1,r,val);Merge(x,L,R);
}
ll AskSum(ll x,ll L,ll R,ll l,ll r){if(L==l&&R==r)return sum[x];ll mid=(L+R)>>1;Downdata(x,L,R);if(r<=mid)return AskSum(x*2,L,mid,l,r);if(l>mid)return AskSum(x*2+1,mid+1,R,l,r);return AskSum(x*2,L,mid,l,mid)+AskSum(x*2+1,mid+1,R,mid+1,r);
}
ll AskMaxa(ll x,ll L,ll R,ll l,ll r){if(L==l&&R==r)return mxa[x];ll mid=(L+R)>>1;Downdata(x,L,R);if(r<=mid)return AskMaxa(x*2,L,mid,l,r);if(l>mid)return AskMaxa(x*2+1,mid+1,R,l,r);return max(AskMaxa(x*2,L,mid,l,mid),AskMaxa(x*2+1,mid+1,R,mid+1,r));
}
ll AskMaxb(ll x,ll L,ll R,ll l,ll r){if(L==l&&R==r)return mxb[x];ll mid=(L+R)>>1;Downdata(x,L,R);if(r<=mid)return AskMaxb(x*2,L,mid,l,r);if(l>mid)return AskMaxb(x*2+1,mid+1,R,l,r);return max(AskMaxb(x*2,L,mid,l,mid),AskMaxb(x*2+1,mid+1,R,mid+1,r));
}
void Build(ll x,ll L,ll R){if(L==R){ll w;scanf("%lld",&w);mxa[x]=mxb[x]=sum[x]=w;se[x]=-inf;t[x]=1;return;}ll mid=(L+R)>>1;Build(x*2,L,mid);Build(x*2+1,mid+1,R);Merge(x,L,R);return;
}
signed main()
{scanf("%lld%lld",&n,&m);Build(1,1,n);while(m--){ll op,l,r,w;scanf("%lld%lld%lld",&op,&l,&r);if(op==1){scanf("%lld",&w);ChangeAdd(1,1,n,l,r,w);}if(op==2){scanf("%lld",&w);ChangeMin(1,1,n,l,r,w);}if(op==3)printf("%lld\n",AskSum(1,1,n,l,r));if(op==4)printf("%lld\n",AskMaxa(1,1,n,l,r));if(op==5)printf("%lld\n",AskMaxb(1,1,n,l,r));}return 0;
}
/*
5 6
1 2 3 4 5
2 1 5 3
3 1 5
*/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317745.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洛谷P1912:诗人小G(二分栈、决策单调性)

二分栈&#xff0c;就是通过二分维护的栈 &#xff08;逃&#xff09; 解析 本题的决策单调性可以说是显然 但是本题是同维度&#xff08;其实只有一维&#xff09;自左向右转移&#xff0c;分治的写法是不能奏效的 所以我们使用决策点调性的另一种实现方法&#xff1a;二分栈…

[国家集训队]middle(二分+主席树[中位数思维题])

文章目录点击查看solutioncode点击查看 solution 简单口胡一下就跑 考虑二分答案ansansans 区间[x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d][x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d][x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d] 大于等于ansansans的设为111&#xff0c;小于ansans…

使用Roslyn脚本化C#代码,C#动态脚本实现方案

来源&#xff1a;https://www.cnblogs.com/7tiny/p/10279349.html【前言】Roslyn 是微软公司开源的 .NET 编译器。编译器支持 C# 和 Visual Basic 代码编译&#xff0c;并提供丰富的代码分析 API。Roslyn不仅仅可以直接编译输出&#xff0c;难能可贵的就是上述描述中的开放了编…

Moving On Gym - 102222F

Moving On Gym - 102222F 题意&#xff1a; 有 n 个城市&#xff0c;q 次询问. 给出每个城市的危险度 r 和 城市的邻接矩阵. 每次询问给出 u、v、w&#xff0c;求从 u 到 v 且不经过其他危险度超过 w 的城市的最短路. 题解&#xff1a; floyd 变形 我队友一开始想的是每次…

10.27模拟 总结

前言 220pts 100200100 按照gg的建议从《暴力模式》转化为《切题模式》 但是感觉本次有点难阿… 进入石头门困境… 再四道题中反复横跳 说实话心态是炸的 T1&#xff08;伪&#xff09;正解出来后才安了一些心 由于这次数据的强度确实不高 T1和T4的做法其实都很假 过掉也有运气…

[构造训练]CF1227G Not Same,CF1375H Set Merging,CF1364E X-OR

文章目录T1&#xff1a;CF1227G Not SamesolutioncodeT2&#xff1a;CF1364E X-ORsolutioncodeT3&#xff1a;CF1375H Set Mergingsolutioncode~~脑子是个好东西&#xff0c;希望人人都有构造真的不是个东西&#xff0c;看了一天视频&#xff0c;没有一道题会做~~ T1&#xff…

asp.net core 环境(Development、Staging 、Production)

一.在asp.net core中使用多个环境ASP.NET Core 配置是基于运行时环境, 使用环境变量。ASP.NET Core 在应用启动时读取环境变量ASPNETCORE_ENVIRONMENT&#xff0c;并将该值存储在 IHostingEnvironment.EnvironmentName 中。ASPNETCORE_ENVIRONMENT 可设置为任意值&#xff0c;但…

AT3913-XOR Tree【状压dp】

正题 题目链接:https://www.luogu.com.cn/problem/AT3913 题目大意 给出一棵有边权的树&#xff0c;你每次可以选择一条链让所有的边异或上同一个值&#xff0c;求最少的操作次数使得所有边的权值都为000。 2≤n≤105,0≤w<162\leq n\leq 10^5,0\leq w<162≤n≤105,0≤…

2018宁夏邀请赛

2018宁夏邀请赛 A Maximum Element In A Stack B Gym 102222B Rolling The Polygon C Gym 102222C Caesar Cipher D Gym 102222D Take Your Seat E Gym 102222E 2-3-4 Tree F Gym 102222F Moving On G Gym 102222G Factories H Gym 102222H Fight Against Monsters I Gym 10222…

洛谷P3349:小星星(容斥dp)

解析 先安利一波洛谷上我介绍如何用暴力日过去的博客 现在开始务正业 考虑把dp记录状态的一维s去掉 这样单次转移复杂度变成n3n^3n3 但是这样显然会算多啊&#xff01; 因为一个编号可能会用很多次 考虑容斥 设ansians_iansi​表示至少浪费了i个编号的答案 那么我们的答案显然…

ASP.NET Core 2.1 : 图解路由(2.1 or earler)

本文通过一张图来看一下路由的配置以及请求处理的机制。 一、概述路由主要有两个主要功能&#xff1a;将请求的URL与已定义的路由进行匹配&#xff0c;找到该URL对应的处理程序并传入该请求进行处理。根据已定义的路由生成URL这两个功能看起来这两个是相反的。A.路由的配置路由…

P2564 [SCOI2009]生日礼物

P2564 [SCOI2009]生日礼物 题意&#xff1a; n个彩珠&#xff0c;k个种类&#xff0c;分布在一个彩带上&#xff0c;现在要选取彩带的一部分&#xff0c;要求该部分包含所有种类的彩珠&#xff0c;且长度尽可能短&#xff0c;你能计算这个最短的长度吗&#xff1f; 1≤N≤100…

P6478-[NOI Online #2 提高组]游戏【dp,二项式反演】

正题 题目链接:https://www.luogu.com.cn/problem/P6478 题目大意 给出2m2m2m个点的一棵树&#xff0c;有mmm个白点mmm个黑点。 每个白点匹配一个黑点。 对于每个k∈[0,m]k\in[0,m]k∈[0,m]求恰好有kkk个匹配存在祖孙关系的方案。 答案对998244353998244353998244353取模。…

洛谷P6302:回家路线(斜率优化)

解析 《论什么是合理的实现》 本题dp的斜率式子还是不难 恶心在其他地方 由于不能时光倒流&#xff0c;新点必须在q时间后再插入 因此我们开一个堆来按找q升序排列&#xff0c;算完一个点就塞到堆里&#xff0c;每次把当前可以插入的点一起弹出来插入 一个重要的技巧是只存储火…

[数据结构专训][GXOI/GZOI2019]旧词,[hdu5118]GRE Words Once More!,[hdu6333]Problem B. Harvest of Apples

文章目录T1&#xff1a;[GXOI/GZOI2019]旧词solutioncodeT2&#xff1a;GRE Words Once More!solutioncodeT3&#xff1a;Problem B. Harvest of ApplessolutioncodeT1&#xff1a;[GXOI/GZOI2019]旧词 点击查看 solution 考虑k1k1k1的情况 由于dep[lca(x,y)]∣{z,zdep[lca(…

浅谈c#垃圾回收机制(GC)

写了一个window服务&#xff0c;循环更新sqlite记录&#xff0c;内存一点点稳步增长。三天后&#xff0c;内存溢出。于是&#xff0c;我从自己的代码入手&#xff0c;查找到底哪儿占用内存释放不掉&#xff0c;最终明确是调用servicestack.ormlite更新sqlite数据库造成的。至于…

动态规划专题复习

很久没做过dp了&#xff0c;都忘得差不多 普通dp 管道取珠 牛客网【每日一题】3月26日 合并回文子串 Music Problem 线性dp 树形dp 概率dp

Loj#6039-「雅礼集训 2017 Day5」珠宝【四边形不等式,dp】

正题 题目链接:https://loj.ac/p/6039 题目大意 有nnn个物品&#xff0c;第iii个费用为wiw_iwi​&#xff0c;价值为viv_ivi​&#xff0c;对于k∈[1,m]k\in[1,m]k∈[1,m]求费用为mmm时能获得的最大价值。 1≤n≤106,1≤m≤5104,1≤wi≤300,1≤vi≤1091\leq n\leq 10^6,1\leq…

洛谷P2497:基站建设(splay、斜率优化)

所谓splay斜率优化dp&#xff0c;就是利用splay和斜率对dp进行优化 &#xff08;逃&#xff09; 解析 在斜优的时候&#xff0c;有时我们会发现我们插入的点的横坐标并不单调 这个时候我们就无法利用单调队列维护凸包了 这时&#xff0c;我们就要请出今天的主角&#xff1a;s…

MediatR 知多少

引言首先不用查字典了&#xff0c;词典查无此词。猜测是作者笔误将Mediator写成MediatR了。废话少说&#xff0c;转入正题。先来简单了解下这个开源项目MediatR&#xff08;作者Jimmy Bogard&#xff0c;也是开源项目AutoMapper的创建者&#xff0c;在此表示膜拜&#xff09;&a…