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 ...
随机推荐
- 使用IDEA配置Maven + SpringMVC + Mybatis 【一步一步踩坑详细配置完成】
PS:初学,想使用Maven配置一个SpringMVC的开发环境,照着网上的各种图文解说,配置了好久都没成功,有些写的不够详细,有些只有写一半,走了不少弯弯绕绕,踩了不少的坑,此文将正确配置成功的步骤 ...
- JavaScript(第三天)【数据类型】
学习要点: 1.typeof操作符 2.Undefined类型 3.Null类型 4.Boolean类型 5.Number类型 6.String类型 7.Object类型 ECMAScript中有5种 ...
- 从0开始的LeetCode生活—9. Palindrome Number(回文数)
题目大意: 判断输入的数字是不是回文数.所谓回文数就是正反读都一样的数字,比如说11,121,1221这样子的数字.负数不会是回文数. 解题思路: 思路一:如果这个数是负数,则返回false,否则用一 ...
- win7如何以管理员身份运行命令提示符(cmd)
1.进入到: C:\Windows\System32 2.找到cmd.exe文件 3.右键单击 ,选择 以管理员身份运行.
- 初谈Git(本机克隆项目远程仓库)
1. 码云注册与新建项目 注册并新建项目 2. Git安装并配置 安装 配置 3. clone项目 附:一些Git命令 git clone 拷贝并跟踪远程的master分支 git add 跟踪新文件 ...
- 20145237 《Java程序设计》第4周学习总结
20145237 <Java程序设计>第4周学习总结 教材学习内容总结 一. 继承 . 定义:面向对象中,涉及对象过多时容易出现重复行为,为了避免这种情况,就可把重复的部分写成父类,由子 ...
- Spring-Data-JPA整合MySQL和配置
一.简介 (1).MySQL是一个关系型数据库系统,是如今互联网公司最常用的数据库和最广泛的数据库.为服务端数据库,能承受高并发的访问量. (2).Spring-Data-Jpa是在JPA规范下提供的 ...
- nyoj 寻找最大数
寻找最大数 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 请在整数 n 中删除m个数字, 使得余下的数字按原次序组成的新数最大, 比如当n=920813467185 ...
- ASCII排序
ASCII码排序 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符. 输入 第一行输 ...
- WebApi 的三种寄宿方式 (一)
最近逛博客园,看到了Owin,学习了一下,做个笔记,说不定将来哪天就用上了 关于 Owin 的介绍,百度解释的很清楚了: https://baike.baidu.com/item/owin/28607 ...