bzoj3463【COCI2012】 Inspector
题目描述
在一个小国家中,一个新的小镇终于建成了!如往常一样,Mirko获得了“首席税务巡查员”的职位。他的任务是保证正确地计算各公司的收入情况。一共有N家办公室坐落在主干道上,从左到右被编号为1~N。一开始,所有办公室一开始都是空的。随后,一些公司会搬入或搬出某些办公室。Mirko时不时地会经过某些办公室并审查在这些办公室中,最富有的公司的账目。
一个公司被以如下的方式描述:
T-表示搬入的第一天。
K-表示搬入的办公室的标号。
Z-公司每日的盈利。(可以是负值表示亏损)
S-公司搬入时的公司财务情况。(即公司的账户资金,也可以是负值)
如果一家公司已经在 K 办公室了,当有新公司要进入 K 办公室时,这家公司会立刻搬出。
新公司第一天并不会运营,盈利从第二天开始计算。
Mirko的审查以 3 个整数来描述:
T-审查的时间。
A 和 B-Mirko会检查 A 办公室至 B 办公室(包括A和B)之间的公司。
Mirko只会在一天结束时检查,所有公司这时已经计算完成了当天利润。
输入格式
第一行包含 2 个正整数:N(1<=N<=100000)表示办公室的数量和M(1<=M<=300000)表示事件的个数。
接下来 M 行,遵循以下格式:“1 T K Z S”或“2 T A B”(含义如题目描述)。其中 T 会严格递增,并且最后一天小于 1000000,Z 和 S 的绝对值也严格小于 1000000。
(注意A可能大于B)
输出格式
对于每次Mirko的审查,每行输出一个整数,表示当天最富有的公司的资产(可以为负)。如果Mirko经过的所有办公室中都没有公司入驻,则输出“nema”(不加引号)。
题解:
- 由于$T$单调递增,所以题意是支持插入,求某个点在标号为$[L,R]$的一次函数上的最大值;
- 答案一定在下凸壳上,分块维护凸壳,有修改操作就打修改标记,查询时遇到修改标记暴力重构区间的凸壳;
- 同时$T$是单调递增的,可以维护每个块的最优值位置,查询向后移动;
- 设分块大小为$B$
- $T = nB \ log B+\frac{n^2}{B} \ \ = n( BlogB + \frac{n}{B})$
- 取$B = \sqrt{\frac{n}{logn}}$,$T = O(n \sqrt{n} \sqrt{log n})$
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<queue>
#include<cmath>
#include<vector>
#include<stack>
#include<map>
#include<set>
#define Run(i,l,r) for(int i=l;i<=r;i++)
#define Don(i,l,r) for(int i=l;i>=r;i--)
#define ll long long
#define ld double
#define mk make_pair
#define fir first
#define sec second
#define il inline
#define rg register
#define pb push_back
using namespace std;
const int N=;
const ll inf = 1e18;
int n,m,u,bl[N],st[N],ed[N],vis[N],mfy[N],L[N],R[N],used[N];
ld px[N];
il char gc(){
static char*p1,*p2,s[];
if(p1==p2)p2=(p1=s)+fread(s,,,stdin);
return(p1==p2)?EOF:*p1++;
}
il int rd(){
int x=,f=; char c=gc();
while(c<''||c>''){if(c=='-')f=-;c=gc();}
while(c>=''&&c<='')x=(x<<)+(x<<)+c-'',c=gc();
return x*f;
}
struct line{
ll k,b;
line(ll _k=,ll _b=):k(_k),b(_b){};
bool operator <(const line&l)const{return k==l.k?b>l.b:k<l.k;}
}a[N],b[N];
ld calx(line x,line y){return (ld)(x.b-y.b)/(y.k-x.k);}
il void build(int x){
int cnt=st[x],top=st[x];
for(rg int i=st[x];i<=ed[x];++i)if(vis[i])b[cnt++]=a[i];
sort(b+st[x],b+cnt);
for(rg int i=st[x]+;i<cnt;++i)if(b[i].k!=b[i-].k){
while(top>st[x]&&calx(b[i],b[top])<px[top-])top--;
px[top]=calx(b[i],b[top]);b[++top]=b[i];
}
L[x]=st[x];R[x]=top;
}
il ll max(ll x,ll y){return x>y?x:y;}
il void query(int T,int x,int y){
if(x>y)swap(x,y);
ll re=-inf;
int l=bl[x],r=bl[y];
if(l==r){for(rg int i=x;i<=y;++i)if(vis[i])re=max(re,a[i].k*T+a[i].b);}
else{
for(rg int i=x;i<=ed[bl[x]];++i)if(vis[i])re=max(re,a[i].k*T+a[i].b);
for(rg int i=st[bl[y]];i<=y;++i)if(vis[i])re=max(re,a[i].k*T+a[i].b);
for(rg int i=l+;i<r;++i){
if(mfy[i])build(i),mfy[i]=,used[i]=;
if(used[i]){
while(L[i]<R[i]&&px[L[i]]<T)L[i]++;
re=max(re,b[L[i]].k*T+b[L[i]].b);
}
}
}
if(re==-inf)puts("nema");else printf("%lld\n",re);
}
int main(){
#ifndef ONLINE_JUDGE
freopen("bzoj3463.in","r",stdin);
freopen("bzoj3463.out","w",stdout);
#endif
n=rd();m=rd();u=sqrt(n/log2(n))+;
for(int i=;i<=n;++i)bl[i]=(i-)/u+;
for(int i=;i<=bl[n];++i)st[i]=ed[i-]+,ed[i]=ed[i-]+u;
ed[bl[n]]=n;
for(int i=,op,T,x,y;i<=m;++i){
op=rd();T=rd();x=rd();y=rd();
if(op&){
vis[x]=;mfy[bl[x]]=;
a[x]=line(y,rd()-(ll)T*y);
}else query(T,x,y);
}
return ;
}//by tkys_Austin;bzoj3463
bzoj3463【COCI2012】 Inspector的更多相关文章
- 【COCI2012】覆盖字符串
[题目描述] 给出一个长度为N的小写字母串,现在Mirko有M个若干长度为Li字符串.现在Mirko要用这M个字符串去覆盖给出的那个字符串的.覆盖时,必须保证:1.Mirko的字符串不能拆开,旋转:2 ...
- 企业IT管理员IE11升级指南【16】—— 使用Compat Inspector快速定位IE兼容性问题
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
- 【题解】Informacije [COCI2012]
[题解]Informacije [COCI2012] 传送门:官方题面 [题目描述] 有一个长度为 \(n\) 的 序列 \(a\)(由 \([1,n]\) 中的数组成,且每个数只会出现一次),现给出 ...
- 企业IT管理员IE11升级指南【17】—— F12 开发者工具
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
- 企业IT管理员IE11升级指南【15】—— 代理自动配置脚本
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
- 企业IT管理员IE11升级指南【1】—— Internet Explorer 11增强保护模式 (EPM) 介绍
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
- 企业IT管理员IE11升级指南【2】—— Internet Explorer 11 对Adobe Flash的支持
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
- 企业IT管理员IE11升级指南【3】—— IE11 新的GPO设置
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
- 企业IT管理员IE11升级指南【4】—— IE企业模式介绍
企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...
随机推荐
- VMware vSphere 6.0 安装及管理手册
目录 1. VMWARE_VSPHERE安装 1.1. 底层ESXI 安装步骤 1.2. VCENTER安装步骤 1) 准备vCenter安装环境 2) vCenter安装步骤 2. VMWARE_V ...
- getField()与getDeclaredField()的区别
Java的反射机制中,用Class的getField(String name)或getDelaredField(String name)可以得到目标类的指定属性,返回类型是Field. 但这两个是有区 ...
- apm server
目录 1.apm的tomcat启动失败解决方法 2.apm的mysql修改root密码的方法 内容: 1.apm的tomcat启动失败解决方法 APMServ5.2.6 无法启动Apache的一个问题 ...
- CANopen 基础
1. TPDO和RPDO都是针对从站来说的,协议上没有有讲任何一个关于主站的概念,协议就只是定义从站,没有定义主站任何东西.TPDO:从站->主站RPDO:主站->从站 2. PDO的CO ...
- Redis4.0模块子系统实现简述
一.模块加载方法 1.在配置文件或者启动参数里面通过<loadmodule /path/to/mymodule.so args>指令加载 2.Redis启动后,通过<module l ...
- C++操作mysql方法总结(1)
C++通过mysql的c api和通过mysql的Connector C++ 1.1.3操作mysql的两种方式 使用vs2013和64位的msql 5.6.16进行操作 项目中使用的数据库名为boo ...
- Java基本程序设计结构
一.要求: 1.设平面上有一个m×n 的网格,将左下角的网格点标记为(0,0)而右上角的网格点标记为(m,n).某人想从(0,0)出发沿网格线行进到达(m,n),但是在网格点(i,j)处他只能向上行进 ...
- HDU 1231 最大子序列
http://acm.hdu.edu.cn/showproblem.php?pid=1231 Problem Description 给定K个整数的序列{ N1, N2, ..., NK },其任意连 ...
- APP端测试与web端测试的区别
想要知道APP端测试与web端测试的区别 ,那么我们就要先来了解,web和app的区别. web项目,一般都是b/s架构,基于浏览器的,而app则是c/s的,必须要有客户端.那么在系统测试测试的时候就 ...
- git add -A 和 git add . 的区别
git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别 git add . :他会监控工作区的状态树,使用它会把工作时的所有变化提交到暂存区,包括文 ...