题目描述

Bob需要一个程序来监视CPU使用率。这是一个很繁琐的过程,为了让问题更加简单,Bob会慢慢列出今天会在用计算机时做什么事。

Bob会干很多事,除了跑暴力程序看视频之外,还会做出去玩玩和用鼠标乱点之类的事,甚至会一脚踢掉电源……这些事有的会让做这件事的这段时间内CPU使用率增加或减少一个值;有的事还会直接让CPU使用率变为一个值。

当然Bob会询问:在之前给出的事件影响下,CPU在某段时间内,使用率最高是多少。有时候Bob还会好奇地询问,在某段时间内CPU曾经的最高使用率是多少。

为了使计算精确,使用率不用百分比而用一个整数表示。

不保证Bob的事件列表出了莫名的问题,使得使用率为负………………

第一行一个正整数T,表示Bob需要监视CPU的总时间。

然后第二行给出T个数表示在你的监视程序执行之前,Bob干的事让CPU在这段时间内每个时刻的使用率达已经达到了多少。

第三行给出一个数E,表示Bob需要做的事和询问的总数。

接下来E行每行表示给出一个询问或者列出一条事件:

  • Q X Y:询问从X到Y这段时间内CPU最高使用率
  • A X Y:询问从X到Y这段时间内之前列出的事件使CPU达到过的最高使用率
  • P X Y Z:列出一个事件这个事件使得从X到Y这段时间内CPU使用率增加Z
  • C X Y Z:列出一个事件这个事件使得从X到Y这段时间内CPU使用率变为Z

时间的单位为秒,使用率没有单位。

X和Y均为正整数(X<=Y),Z为一个整数。

从X到Y这段时间包含第X秒和第Y秒。

保证必要运算在有符号32位整数以内。

题解

这道题如果没有第二个操作的话,就是一道线段树入门题。

现在要求维护历史最大值,我们需要在线段树上的懒标记上下手。

我们令一个标记为(a,b)表示当前add的数为x,达到的最大值为y。

那么合并两个标记(a,b)(c,d)就是(a+c,max(b+c,d))。

最后面的取max是讨论了当前操作是修改还是增量,若增量就取前者,否则取后者。

然后我们对线段树上的每一个节点维护两个标记,当前标记和历史最大标记。

对于历史标记的维护,我们就把当前标记加上刚来的标记后和这个历史标记按位取个max。

对于当前标记直接合并即可。

同时维护两个变量:当前最大值和历史最大值,这个比较好维护。

代码

#include<iostream>
#include<cstdio>
#define ls tr[cnt].l
#define rs tr[cnt].r
#define inf 1e9
#define N 100009
using namespace std;
char s[];
inline int rd(){
int x=;char c=getchar();bool f=;
while(!isdigit(c)){if(c=='-')f=;c=getchar();}
while(isdigit(c)){x=(x<<)+(x<<)+(c^);c=getchar();}
return f?-x:x;
}
struct node{
int x,y;
node(int xx=,int yy=-inf){x=xx;y=yy;}
inline node operator +(const node &b)const{return node(max((int)-inf,x+b.x),max(y+b.x,b.y));}
inline node operator *(const node &b)const{return node(max(x,b.x),max(y,b.y));}
};
int tot=;
struct seg{
int l,r;
node now,la;
int nowmax,lamax;
}tr[N<<];
inline void pushup(int cnt){
tr[cnt].nowmax=max(tr[ls].nowmax,tr[rs].nowmax);
tr[cnt].lamax=max(tr[ls].lamax,tr[rs].lamax);
}
inline void pushdown(int cnt){
node x=tr[cnt].now,y=tr[cnt].la;
tr[rs].la=tr[rs].la*(tr[rs].now+y);
tr[rs].now=tr[rs].now+x;
tr[rs].lamax=max(tr[rs].lamax,max(tr[rs].nowmax+y.x,y.y));
tr[rs].nowmax=max(tr[rs].nowmax+x.x,x.y);
tr[ls].la=tr[ls].la*(tr[ls].now+y);
tr[ls].now=tr[ls].now+x;
tr[ls].lamax=max(tr[ls].lamax,max(tr[ls].nowmax+y.x,y.y));
tr[ls].nowmax=max(tr[ls].nowmax+x.x,x.y);
tr[cnt].now=tr[cnt].la=node();
}
void build(int cnt,int l,int r){
tr[cnt].now=tr[cnt].la=node();
if(l==r){tr[cnt].nowmax=rd();tr[cnt].lamax=tr[cnt].nowmax;return;}
int mid=(l+r)>>;
ls=++tot;rs=++tot;
build(ls,l,mid);build(rs,mid+,r);
pushup(cnt);
}
void upd(int cnt,int l,int r,int L,int R,node x){
if(l>=L&&r<=R){
tr[cnt].la=tr[cnt].la*(tr[cnt].now+x);
tr[cnt].now=tr[cnt].now+x;
tr[cnt].nowmax=max(tr[cnt].nowmax+x.x,x.y);
tr[cnt].lamax=max(tr[cnt].lamax,tr[cnt].nowmax);
return;
}
int mid=(l+r)>>;
pushdown(cnt);
if(mid>=L)upd(ls,l,mid,L,R,x);
if(mid<R)upd(rs,mid+,r,L,R,x);
pushup(cnt);
}
int query(int cnt,int l,int r,int L,int R,int tag){
if(l>=L&&r<=R)return tag?tr[cnt].nowmax:tr[cnt].lamax;
int mid=(l+r)>>;
pushdown(cnt);
if(mid>=L&&mid<R)return max(query(ls,l,mid,L,R,tag),query(rs,mid+,r,L,R,tag));
else if(mid>=L)return query(ls,l,mid,L,R,tag);else if(mid<R)return query(rs,mid+,r,L,R,tag);
}
int main(){
int n=rd();
build(,,n);
int q=rd();int x,y,z;
while(q--){
scanf("%s",s);x=rd();y=rd();
if(s[]=='Q'){
printf("%d\n",query(,,n,x,y,));
}
else if(s[]=='A'){
printf("%d\n",query(,,n,x,y,));
}
else if(s[]=='P'){
z=rd();
upd(,,n,x,y,node(z,-inf));
}
else{
z=rd();
upd(,,n,x,y,node(-inf,z));
}
}
return ;
}

CPU监控的更多相关文章

  1. C#实现对远程服务器的内存和CPU监控

    C#实现对远程服务器的内存和CPU监控小记 1.  主要使用到的组件有System.Management.dll 2.  主要类为 :ManagementScope 连接远程服务器示例代码: priv ...

  2. Linux CPU监控指标

    Linux CPU监控指标 Linux提供了非常丰富的命令可以进行CPU相关数据进行监控,例如:top.vmstat等命令.top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执 ...

  3. [补档][Tyvj 1518]CPU监控

    [Tyvj 1518]CPU监控 题目 Bob需要一个程序来监视CPU使用率.这是一个很繁琐的过程,为了让问题更加简单,Bob会慢慢列出今天会在用计算机时做什么事. Bob会干很多事,除了跑暴力程序看 ...

  4. CPU监控 解题报告

    CPU监控 这种题就需要小黄鸭调试法,不行就重构,动态gdb可能会死人,一堆tag的... 维护历史最值的一个核心是历史最值tag,它的意义是从上一次这个点下放tag之后到当前时刻的这个点的tag达到 ...

  5. 【BZOJ3064】CPU监控(线段树)

    [BZOJ3064]CPU监控(线段树) 题面 BZOJ 洛谷 题解 神仙\(zsy\)出在了\(noip\)模拟的题目.(然而\(zsy\)出的还是这题的升级版) 首先明确一点,这题是一个吉司机线段 ...

  6. BZOJ 3064 CPU监控

    题目链接:CPU监控 学习一番线段树的历史标记- 这道题就是区间加法,区间赋值,要询问区间最大值 和 区间历史最大值的最大值. 然后这种题就是在现有标记的基础上多弄一套标记,维护这个点出现过的最大的标 ...

  7. 安卓app测试之cpu监控

    安卓app测试之cpu监控,如何获取监控的cpu数据呢? 一.通过Dumpsys 来取值 1.adb shell dumpsys cpuinfo 二.top 1.top -d 1|grep packa ...

  8. 轻量级监控平台之cpu监控

    轻量级监控平台之cpu监控脚本 #!/bin/bash #进程监控脚本 #功能需求: 上报机器的硬件层面-cpu负载数据 . /etc/profile . ~/.bash_profile pushur ...

  9. [BZOJ3064][Tyvj1518] CPU监控

    题目:[BZOJ3064][Tyvj1518] CPU监控 思路: 线段树专题讲的.以下为讲课时的课件: 给出序列,要求查询一些区间的最大值.历史最大值,支持区间加.区间修改.序列长度和操作数< ...

  10. 基于 HTML5 WebGL 的 CPU 监控系统

    前言 科技改变生活,科技的发展带来了生活方式的巨大改变.随着通信技术的不断演进,5G 技术应运而生,随时随地万物互联的时代已经来临.5G 技术不仅带来了更快的连接速度和前所未有的用户体验,也为制造业, ...

随机推荐

  1. 从零开始学安全(四十五)●browser_autopwn2漏洞利用配合Ettercap工具实施DNS欺骗攻击

    系统:kali 2019  工具Ettercap,Metasploit 环境内网地址 首先 cd /etc/ettercap/ 移动在ettercap 文件下 在用vim 打开编辑 etter.dns ...

  2. String方法

    String 大小写转换: String str = "ABC";String str1 = "abc"; System.out.println("A ...

  3. OO_BLOG2_多线程电梯模拟

    作业2-1 单部多线程傻瓜调度(FAFS)电梯的模拟 I. 基于度量的程序结构分析 1)程序结构与基本度量统计图 2)分析 ​ 这次作业基本奠定了本人三次电梯作业的基本架构,简述如下: Elevato ...

  4. Java自增和自减操作符——++/--的那些事

    1. 概述 自增操作符(++)和自减操作符(--)是对变量进行加1和减1的操作. 2.分类说明 ++和--是对变量进行自增1和自减1的简写操作符.许多编程任务中经常需要对变量加1或者减1,所以采用这两 ...

  5. html文档知识补充

    13.form表单(*******) 功能:前后数据交互,帮你提交任意的数据 input通过控制type属性来展示不同的获取用户输入的页面效果 type属性总结: text:纯文本 password: ...

  6. 16进制字符串转QByteArray,char转16进制字符串

    直接上代码,看代码你们就懂了 1.16进制QString转QByteArray QString str = "01 a5 1e 02"; QByteArray tmpBy; Str ...

  7. 斐波那契数列(C#)

    斐波那契数,亦称之为斐波那契数列(意大利语: Successione di Fibonacci),又称黄金分割数列.费波那西数列.费波拿契数.费氏数列,指的是这样一个数列:1.1.2.3.5.8.13 ...

  8. 解决ajax跨域访问sessionid不一致问题

    根据浏览器的保护规则,跨域的时候我们创建的sessionId是不会被浏览器保存下来的,这样,当我们在进行跨域访问的时候,我们的sessionId就不会被保存下来,也就是说,每一次的请求,服务器就会以为 ...

  9. C语言面试程序阅读整理

    一.数组和指针 1.数组和指针的存储 写出下面的输出结果: char str1[] = "abc"; char str2[] = "abc"; const ch ...

  10. Mac Git 安装和配置

    一.git下载与安装 点击Git,然后选择下载安装包 git --version,终端输入该命令, 如输出版本号,则说明安装成功. git version 2.20.1 二.git基本配置 通过下面这 ...