luogu P4314 CPU监控
这是个远古巨坑阿qwq
没有历史最大值还是能比较好做的.可能会有一个想法,就是直接维护线段树每个结点出现过的历史最大值,每次最大值变化就更新.但是有个问题:可能一个点能影响历史最大值的标记还没被及时下放,就被父亲标记覆盖了,这样就可能得到错误答案
考虑新定义标记\((a,b)\),表示对一个结点先加\(a\)然后和\(b\)求max.这种定义下,区间加就是\((x,-\infty)\),赋值就是\((-\infty,x)\).然后如果两个标记合并,假设是\((a,b)\)并上\((x,y)\),那么应该是\((a+x,max(b+x,y))\).手玩发现这样是对的
但是还是没解决历史最大值的问题.现在多开一种标记,表示影响历史最大值的标记.这一种标记\((a,b)\)并上\((x,y)\)应该是\((max(a,x),max(b,y))\),原因是可以看成是两个分段函数取max
然后就没然后了,线段树怎么搞就怎么搞
#include<bits/stdc++.h>
#define LL long long
#define ldb long double
#define il inline
#define re register
using namespace std;
const int N=1e5+10,inf=999999999;
il int rd()
{
int x=0,w=1;char ch=0;
while(ch<'0'||ch>'9') {if(ch=='-') w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') {x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*w;
}
struct TAG
{
int a,b;
TAG(){a=0,b=-inf;}
TAG(int na,int nb){a=na,b=nb;}
il void clr(){a=0,b=-inf;}
TAG operator + (const TAG &bb) const {return TAG(max(-inf,a+bb.a),max(b+bb.a,bb.b));} //小心boom int
TAG operator & (const TAG &bb) const {return TAG(max(a,bb.a),max(b,bb.b));}
}nt[N<<2],ht[N<<2];
int ns[N<<2],hs[N<<2];
il void psup(int o){hs[o]=max(hs[o<<1],hs[o<<1|1]),ns[o]=max(ns[o<<1],ns[o<<1|1]);}
il void ad(int o,TAG x,TAG y)
{
ht[o]=ht[o]&(nt[o]+y);
nt[o]=nt[o]+x;
hs[o]=max(hs[o],max(ns[o]+y.a,y.b));
ns[o]=max(ns[o]+x.a,x.b);
}
il void psdn(int o)
{
ad(o<<1,nt[o],ht[o]),ad(o<<1|1,nt[o],ht[o]);
nt[o].clr(),ht[o].clr();
}
#define mid ((l+r)>>1)
void modif(int o,int l,int r,int ll,int rr,TAG x)
{
if(ll<=l&&r<=rr) {ad(o,x,x);return;}
psdn(o);
if(ll<=mid) modif(o<<1,l,mid,ll,rr,x);
if(rr>mid) modif(o<<1|1,mid+1,r,ll,rr,x);
psup(o);
}
int quer(int o,int l,int r,int ll,int rr,bool op)
{
if(ll<=l&&r<=rr) return op?hs[o]:ns[o];
psdn(o);
int an=-inf;
if(ll<=mid) an=max(an,quer(o<<1,l,mid,ll,rr,op));
if(rr>mid) an=max(an,quer(o<<1|1,mid+1,r,ll,rr,op));
psup(o);
return an;
}
void bui(int o,int l,int r)
{
if(l==r){ns[o]=hs[o]=rd();return;}
bui(o<<1,l,mid),bui(o<<1|1,mid+1,r);
psup(o);
}
int n,q;
int main()
{
n=rd();
bui(1,1,n);
q=rd();
char cc[2];
while(q--)
{
scanf("%s",cc);
if(cc[0]=='Q')
{
int l=rd(),r=rd();
printf("%d\n",quer(1,1,n,l,r,0));
}
else if(cc[0]=='A')
{
int l=rd(),r=rd();
printf("%d\n",quer(1,1,n,l,r,1));
}
else if(cc[0]=='P')
{
int l=rd(),r=rd(),x=rd();
modif(1,1,n,l,r,TAG(x,-inf));
}
else
{
int l=rd(),r=rd(),x=rd();
modif(1,1,n,l,r,TAG(-inf,x));
}
}
return 0;
}
luogu P4314 CPU监控的更多相关文章
- P4314 CPU监控
题面 这是一道堪称"线段树3"的线段树好题,对于\(lazy\)标记的操作可以说是非常巧妙 我们用结构体来记录\(lazy\)标记,结构体中定义\(a,b\)两个元素,\(a\)表 ...
- bzoj3064/洛谷P4314 CPU监控【线段树】
好,长草博客被催更了[?] 我感觉这题完全可以当作线段树3 线段树2考加法和乘法标记的下放顺序,这道题更丧心病狂[?] 很多人可能跟我一样,刚看到这道题秒出思路:打一个当前最大值一个历史最大值不就完事 ...
- C#实现对远程服务器的内存和CPU监控
C#实现对远程服务器的内存和CPU监控小记 1. 主要使用到的组件有System.Management.dll 2. 主要类为 :ManagementScope 连接远程服务器示例代码: priv ...
- Linux CPU监控指标
Linux CPU监控指标 Linux提供了非常丰富的命令可以进行CPU相关数据进行监控,例如:top.vmstat等命令.top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执 ...
- [补档][Tyvj 1518]CPU监控
[Tyvj 1518]CPU监控 题目 Bob需要一个程序来监视CPU使用率.这是一个很繁琐的过程,为了让问题更加简单,Bob会慢慢列出今天会在用计算机时做什么事. Bob会干很多事,除了跑暴力程序看 ...
- CPU监控 解题报告
CPU监控 这种题就需要小黄鸭调试法,不行就重构,动态gdb可能会死人,一堆tag的... 维护历史最值的一个核心是历史最值tag,它的意义是从上一次这个点下放tag之后到当前时刻的这个点的tag达到 ...
- 【BZOJ3064】CPU监控(线段树)
[BZOJ3064]CPU监控(线段树) 题面 BZOJ 洛谷 题解 神仙\(zsy\)出在了\(noip\)模拟的题目.(然而\(zsy\)出的还是这题的升级版) 首先明确一点,这题是一个吉司机线段 ...
- BZOJ 3064 CPU监控
题目链接:CPU监控 学习一番线段树的历史标记- 这道题就是区间加法,区间赋值,要询问区间最大值 和 区间历史最大值的最大值. 然后这种题就是在现有标记的基础上多弄一套标记,维护这个点出现过的最大的标 ...
- 安卓app测试之cpu监控
安卓app测试之cpu监控,如何获取监控的cpu数据呢? 一.通过Dumpsys 来取值 1.adb shell dumpsys cpuinfo 二.top 1.top -d 1|grep packa ...
随机推荐
- Python使用import导入相对路径的其他py文件
假如有如下的目录结构 . ├── setup.py ├── main.py ├── mod/ │ └── mod.py └── sub/ └── sub.py 情况1:setup.py导入main ...
- yzh的神仙题
U66905 zz题 考虑一个点权值被计算了多少次...不知 所以对未来承诺,方便直接算上总数! 然后其实是给边定向,即先删除fa和son的哪一个 f[x][j],会计算j次 无法转移 f[x][j] ...
- python 类的介绍
使用面向对象的优点: 1.能够更好的设计软件架构 2.维护软件模块 3.易于架构和组件的重用 类的定义: 构造函数:初始化用,写不写都可以,默认为空 类属性:属于类的对象 方法属性:不属于类的对象 私 ...
- argparse模块的应用
主要参照博客https://www.cnblogs.com/lindaxin/p/7975697.html http://wiki.jikexueyuan.com/project/explore-py ...
- PHP工厂方法模式
此模式中,通过定义一个抽象的核心工厂类,并定义创建产品对象的接口,创建具体产品实例的工作延迟到其工厂子类去完成.这样做的好处是核心类只关注工厂类的接口定义,而具体的产品实例交给具体的工厂子类去创建.当 ...
- 快速傅里叶变换(FFT)_转载
FFTFFT·Fast Fourier TransformationFast Fourier Transformation快速傅立叶变换 P3803 [模板]多项式乘法(FFT) 参考上文 首 ...
- Js封装的动画函数实现轮播图
---恢复内容开始--- 效果图说明:当鼠标移到哪一个按钮上的时候会自动跳转到某一张图片上,并且按钮会以高亮显示 项目目录结构 用到的js封装的animate()动画 function ...
- php php-fpm安装 nginx配置php
centos 6.2 linux下安装php5.6.6源码 PHP在 5.3.3 之后已经把php-fpm并入到php的核心代码中了. 所以php-fpm不需要单独的下载安装.要想php支持php-f ...
- BZOJ2006 ST表 + 堆
https://www.lydsy.com/JudgeOnline/problem.php?id=2006 题意:在长度N的序列中求K段长度在L到R之间的区间,使得他们的和最大 很容易想到要求一个前缀 ...
- 10 个 Linux 中方便的 Bash 别名
10 个方便的 Bash 别名 1. 你有几次遇到需要解压 .tar 文件但无法记住所需的确切参数?别名可以帮助你!只需将以下内容添加到 .bash_profile 中,然后使用 untar File ...