BZOJ 3938 Robot
Description
Input
Output
Sample Input
-20 0 20 100
10 command 1 10
20 command 3 -10
30 query
40 command 1 -30
50 query
Sample Output
280
HINT
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
using namespace std;
typedef long long lol;
struct ZYYS
{
lol l,r,k,id,b;
};
struct rubbish
{
lol t,k,id;
bool kind;
}q[];
struct caiji
{
int p,x;
}b[];
struct Line
{
lol k,b;
bool id;
}tree1[],tree2[];
lol h[],nowb[],nowk[],a[];
lol ansmax,ansmin,T;
int n,m,num,size;
char ch[];
lol gi()
{
lol x=,flag=;
char c=getchar();
while (c<''||c>'')
{
if (c=='-') flag=-;
c=getchar();
}
while (c>=''&&c<='')
{
x=x*+c-'';
c=getchar();
}
return x*flag;
}
bool pd(Line a,Line b,lol x)
{
return a.k*x+a.b>b.k*x+b.b;
}
double cross(Line a,Line b)
{
return (a.b-b.b)/(1.0*(b.k-a.k));
}
lol cal(Line a,lol x)
{
return a.k*x+a.b;
}
void add_max(int rt,int l,int r,Line x)
{
if (l>r) return;
if (!tree1[rt].id)
{
tree1[rt]=x;
return;
}
lol f1=cal(x,h[l]);lol f2=cal(tree1[rt],h[l]);
lol f3=cal(x,h[r]);lol f4=cal(tree1[rt],h[r]);
if (f1<=f2&&f3<=f4) return;
if (f1>=f2&&f3>=f4)
{tree1[rt]=x;return;}
int mid=(l+r)/;
double p=cross(tree1[rt],x);
if (f1>=f2)
{
if (p<=h[mid]) add_max(rt<<,l,mid,x);
else add_max(rt<<|,mid+,r,tree1[rt]),tree1[rt]=x;
}
else
{
if (p>h[mid]) add_max(rt<<|,mid+,r,x);
else add_max(rt<<,l,mid,tree1[rt]),tree1[rt]=x;
}
}
void add_min(int rt,int l,int r,Line x)
{
if (l>r) return;
if (!tree2[rt].id)
{
tree2[rt]=x;
return;
}
lol f1=cal(x,h[l]);lol f2=cal(tree2[rt],h[l]);
lol f3=cal(x,h[r]);lol f4=cal(tree2[rt],h[r]);
if (f1>=f2&&f3>=f4) return;
if (f1<=f2&&f3<=f4)
{tree2[rt]=x;return;}
int mid=(l+r)/;
double p=cross(tree2[rt],x);
if (f1<=f2)
{
if (p<=h[mid]) add_min(rt<<,l,mid,x);
else add_min(rt<<|,mid+,r,tree2[rt]),tree2[rt]=x;
}
else
{
if (p>h[mid]) add_min(rt<<|,mid+,r,x);
else add_min(rt<<,l,mid,tree2[rt]),tree2[rt]=x;
}
}
void update_max(int rt,int l,int r,int L,int R,Line x)
{
if (L>R) return;
if (l>r) return;
if (l>=L&&r<=R)
{
add_max(rt,l,r,x);
return;
}
int mid=(l+r)/;
if (L<=mid) update_max(rt<<,l,mid,L,R,x);
if (R>mid) update_max(rt<<|,mid+,r,L,R,x);
}
void update_min(int rt,int l,int r,int L,int R,Line x)
{
if (L>R) return;
if (l>r) return;
if (l>=L&&r<=R)
{
add_min(rt,l,r,x);
return;
}
int mid=(l+r)/;
if (L<=mid) update_min(rt<<,l,mid,L,R,x);
if (R>mid) update_min(rt<<|,mid+,r,L,R,x);
}
void query_max(int rt,int l,int r,int x)
{
if (l>r) return;
if (tree1[rt].id) ansmax=max(ansmax,cal(tree1[rt],h[x]));
//cout<<ansmax<<endl;
if (l==r)
{
return ;
}
int mid=(l+r)/;
if (x<=mid) query_max(rt<<,l,mid,x);
else query_max(rt<<|,mid+,r,x);
return ;
}
void query_min(int rt,int l,int r,int x)
{
if (l>r) return ;
if (tree2[rt].id)
ansmin=min(ansmin,cal(tree2[rt],h[x]));
//cout<<ansmin<<endl;
if (l==r)
{
return ;
}
int mid=(l+r)/;
if (x<=mid) query_min(rt<<,l,mid,x);
else query_min(rt<<|,mid+,r,x);
return ;
}
int main()
{lol i,x,j,p;
lol k,pos;
//freopen("robot.in","r",stdin);
//freopen("robot.out","w",stdout);
n=gi();m=gi();
for (i=;i<=n;i++)
{
nowb[i]=gi();a[i]=;nowk[i]=;
}
h[]=;
for (i=;i<=m;i++)
{
q[i].t=gi();
h[i+]=q[i].t;
scanf("%s",ch);
if (ch[]=='c')
{
q[i].id=gi();q[i].k=gi();
q[i].kind=;
}
}
size=unique(h+,h+m+)-h-;
for (i=;i<=m;i++)
if (q[i].kind)
{
int x=q[i].id;
int lst=lower_bound(h+,h+size+,a[x])-h;
int now=lower_bound(h+,h+size+,q[i].t)-h;
update_max(,,size,lst,now,(Line){nowk[x],nowb[x],});
update_min(,,size,lst,now,(Line){nowk[x],nowb[x],});
//cout<<lst<<' '<<now<<' '<<nowk[x]<<' '<<nowb[x]<<endl;
nowb[x]=nowb[x]+q[i].t*(nowk[x]-q[i].k);
nowk[x]=q[i].k;a[x]=q[i].t;
}
for (i=;i<=n;i++)
{
int lst=lower_bound(h+,h+size+,a[i])-h;
update_max(,,size,lst,size,(Line){nowk[i],nowb[i],});
update_min(,,size,lst,size,(Line){nowk[i],nowb[i],});
//cout<<lst<<' '<<size<<' '<<nowk[i]<<' '<<nowb[i]<<endl;
}
for (i=;i<=m;i++)
if (q[i].kind==)
{
ansmax=;
ansmin=;
int t=lower_bound(h+,h+size+,q[i].t)-h;
query_max(,,size,t);
query_min(,,size,t);
printf("%lld\n",max(ansmax,-ansmin));
}
}
BZOJ 3938 Robot的更多相关文章
- BZOJ.3938.Robot(李超线段树)
BZOJ UOJ 以时间\(t\)为横坐标,位置\(p\)为纵坐标建坐标系,那每个机器人就是一条\(0\sim INF\)的折线. 用李超线段树维护最大最小值.对于折线分成若干条线段依次插入即可. 最 ...
- bzoj3938 Robot
3938: Robot Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 336 Solved: 112[Submit][Status][Discuss ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 1408: [Noi2002]Robot
1408: [Noi2002]Robot Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 510 Solved: 344[Submit][Status][ ...
- 【BZOJ】【3205】【APIO2013】机器人robot
斯坦纳树 好神啊……Orz zyf && PoPoQQQ 为啥跟斯坦纳树扯上关系了?我想是因为每个点(robot)都沿着树边汇到根的时候就全部合起来了吧= =这个好像和裸的斯坦纳树不太 ...
- bzoj千题计划220:bzoj3938: Robot
http://www.lydsy.com/JudgeOnline/problem.php?id=3938 以时间为x轴,以距离为y轴,那么每个机器人的行走路径就是一条折线 把折线分段加入线段树里,然后 ...
- bzoj 1408 [Noi2002]Robot(欧拉函数)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1408 [题意] 求m的所有约数中,满足可以分解成(奇数个不同素数/偶数个不同素数/其 ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
随机推荐
- 冲刺NO.8
Alpha冲刺第八天 站立式会议 项目进展 项目稳步进行,项目的基础部分如基本信息管理,信用信息管理等部分已相对比较完善. 问题困难 技术困难在短期内很难发生质的变化,而本项目由于选择了队员不太熟悉的 ...
- QTableView
QTableView常用于实现数据的表格显示.下面我们如何按步骤实现学生信息表格: 一 添加表头 //准备数据模型 QStandardItemModel *student_model = ne ...
- HTML标签小记文本类标签
文本类标签: <input type="text" name="" value="">文本框 type(方式,方法)name文 ...
- VMware虚拟机误删除vmdk文件后如何恢复?
故障描述: Dell R710系列服务器(用于VMware虚拟主机),Dell MD 3200系列存储(用于存放虚拟机文件),VMware ESXi 5.5版本,因意外断电,导致某台虚拟机不能正常启动 ...
- 北亚关于HP EVA4400/6400/8400/P6000的数据恢复解决方案
[引言]本文档建立在针对HP EVA的大量测试性研究基础上,所有的细节几乎均为对EVA的破译型研究,目前全球范围内尚未发现类似资料,故可能表述方式和结论并不精确,仅为参考之用.我们公司为研究HP EV ...
- nyoj 鸡兔同笼
鸡兔同笼 时间限制:3000 ms | 内存限制:65535 KB 难度:1 描述 已知鸡和兔的总数量为n,总腿数为m.输入n和m,依次输出鸡和兔的数目,如果无解,则输出"No an ...
- ASCII排序
ASCII码排序 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符. 输入 第一行输 ...
- .Net Core MongoDB 简单操作。
一:MongoDB 简单操作类.这里引用了MongoDB.Driver. using MongoDB.Bson; using MongoDB.Driver; using System; using S ...
- JAVA_SE基础——44.抽象类的练习
抽象类要注意的细节: 1. 如果一个函数没有方法体,那么该函数必须要使用abstract修饰,把该函数修饰成抽象 的函数..2. 如果一个类出现了抽象的函数,那么该类也必须 使用abstract修饰. ...
- js 中bind
function fn(a){ this.innerHTML = a; console.log(this); } //fn("hello"); span1.onclick =fun ...