BZOJ3938:Robot
浅谈标记永久化:https://www.cnblogs.com/AKMer/p/10137227.html
题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=3938
首先,操作的个数小于等于\(6*10^5\),因为这个我对着我的程序干瞪眼白白浪费了半个晚上和半个早上。
另外,由于是求离原点距离最远的,所以应该把所有的线段都移到\(y\)的正半轴上来。
转化题意:对于\(i\)号机器人从第\(x\)秒到第\(y\)秒都按照\(k\)的速度移动,第\(x\)秒在\(st\),第\(y\)秒在\(ed\),我们可以算出一次函数的\(b\),然后在一次函数\(y=kx+b\)上面截取\(x\)到\(y\)丢到李超线段树里去维护。
最后,这题跟BZOJ3165:[HEOI2013]Segment基本一样。
时间复杂度:\(O(nlog^2n)\)
空间复杂度:\(O(n)\)
代码如下:
#include <cstdio>
#include <algorithm>
using namespace std;
typedef long long ll;
const int maxn=6e5+5;
int n,m,cnt,tot;
int pos[maxn],nxt[maxn],tim[maxn*4];
int a[maxn],t[maxn],opt[maxn],id[maxn],x[maxn];
int read() {
int x=0,f=1;char ch=getchar();
for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
for(;ch>='0'&&ch<='9';ch=getchar())x=x*10+ch-'0';
return x*f;
}
struct Line {
ll b;
int st,ed,k;
Line() {}
Line(int _st,int _ed,ll _b,int _k) {
st=_st,ed=_ed,b=_b,k=_k;
}
}line[maxn*4];
struct segment_tree {
int tag[maxn<<3];
ll calc(int id,int x) {
return line[id].b+1ll*x*line[id].k;
}
bool check(int id1,int id2,int x) {
return calc(id1,x)<calc(id2,x);
}
ll query(int p,int l,int r,int pos) {
if(l==r)return calc(tag[p],tim[l]);
int mid=(l+r)>>1;ll ans=calc(tag[p],tim[pos]);
if(pos<=mid)ans=max(ans,query(p<<1,l,mid,pos));
else ans=max(ans,query(p<<1|1,mid+1,r,pos));
return ans;
}
void change(int p,int l,int r,int id) {
if(l==r) {
if(check(tag[p],id,tim[l]))tag[p]=id;
return;
}
int mid=(l+r)>>1;
if(line[id].k>line[tag[p]].k) {
if(check(tag[p],id,tim[mid]))change(p<<1,l,mid,tag[p]),tag[p]=id;
else change(p<<1|1,mid+1,r,id);
}
else if(line[id].k==line[tag[p]].k) {
if(check(tag[p],id,tim[mid]))tag[p]=id;
}
else {
if(check(tag[p],id,tim[mid]))change(p<<1|1,mid+1,r,tag[p]),tag[p]=id;
else change(p<<1,l,mid,id);
}
}
void ins(int p,int l,int r,int L,int R,int id) {
if(L<=l&&r<=R) {change(p,l,r,id);return;}
int mid=(l+r)>>1;
if(L<=mid)ins(p<<1,l,mid,L,R,id);
if(R>mid)ins(p<<1|1,mid+1,r,L,R,id);
}
}T;
void make_line(int l,int r,ll B,int K) {
l=t[l],r=t[r];
ll st=B,ed=B+1ll*K*(r-l);B=ed-1ll*r*K;
if(st<=0&&ed<=0)line[++cnt]=Line(l,r,-B,-K);
else if(st>=0&&ed>=0)line[++cnt]=Line(l,r,B,K);
else {
int T=(-B)/K;tim[++tot]=T;
if(st>=0)line[++cnt]=Line(l,T,B,K),line[++cnt]=Line(T+1,r,-B,-K);
else line[++cnt]=Line(l,T,-B,-K),line[++cnt]=Line(T+1,r,B,K);
}
}
void solve_lines() {
for(int i=1;i<=n;i++) {
make_line(1,pos[i],a[i],0);
int now=pos[i];ll B=a[i];
while(now<m) {
make_line(now,nxt[now],B,x[now]);
B=B+1ll*x[now]*(t[nxt[now]]-t[now]);
now=nxt[now];
}
}
}
int main() {
n=read(),tot=m=read();
for(int i=1;i<=n;i++)
a[i]=read(),pos[i]=m;
for(int i=1;i<=m;i++) {
tim[i]=t[i]=read();
char s[20];scanf("%s",s+1);
if(s[1]=='q')opt[i]=1;
else opt[i]=2;
if(opt[i]==2)id[i]=read(),x[i]=read();
}
for(int i=m;i;i--)
if(opt[i]==2)nxt[i]=pos[id[i]],pos[id[i]]=i;
solve_lines();sort(tim+1,tim+tot+1);
int num=unique(tim+1,tim+tot+1)-tim-1;
tot=num;
for(int i=1;i<=cnt;i++) {
int l=lower_bound(tim+1,tim+tot+1,line[i].st)-tim;
int r=lower_bound(tim+1,tim+tot+1,line[i].ed)-tim;
T.ins(1,1,tot,l,r,i);
}
for(int i=1;i<=m;i++)
if(opt[i]==1) {
int q=lower_bound(tim+1,tim+tot+1,t[i])-tim;
printf("%lld\n",T.query(1,1,tot,q));
}
return 0;
}
BZOJ3938:Robot的更多相关文章
- 关于《自动化测试实战宝典:Robot Framework + Python从小工到专家》
受新冠疫情影响,笔者被“困”在湖北老家七十余天,于4月1号(愚人节)这天,终于返回到广州.当前国内疫情基本已趋于平稳,但全球疫情整体势态仍在持续疯涨,累计确诊病例已近80万人.祈祷这场全球性灾难能尽早 ...
- 简单介绍下自动化框架:Robot Framework
一.简介: Robot Framework:Robot Framework是由Python编写的一款功能丰富并且扩展性强的自动化测试框架,也可以在Java和 .NET 上运行. HttpRunner: ...
- RobotFramework-RIDE环境搭建二:Robot Framework-RIDE安装过程以及踩雷点
前期准备工作: Python 2.7(上篇文章中已安装成功) Robot Framework-2.8.5 Robot Framework-RIDE-1.5.2.1 (测试用例的创建.运行可以在图形界面 ...
- SPOJ:Robot(数学期望)
There is a robot on the 2D plane. Robot initially standing on the position (0, 0). Robot can make a ...
- POJ 1573:Robot Motion
Robot Motion Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 11324 Accepted: 5512 Des ...
- 一:robot framework环境安装
1.安装robot framework: 打开cmd进入dos下,输入 pip install robotframework Microsoft Windows [版本 10.0.18362.267] ...
- 【bzoj3938】 Robot
http://www.lydsy.com/JudgeOnline/problem.php?id=3938 (题目链接) 题意 给出数轴上$n$个点,有$m$个操作,在时间$t$让一个点以一定的速度移动 ...
- 三:robot framework常用关键字
该部分介绍的是内置库:Builtin,估不需要导入,即可使用 1.RF中定义一个变量: ${XXX} XXX表示:变量名 *** Settings *** *** Test Cases *** 定 ...
- 二:robot framework基本组成
1.RF组成:套件.用例.关键字 套件:测试用例的集合,可以是一个模块的功能点的集合.也可以是很多模块功能点的集合 用例:一般是由多个关键字组成的 关键字:测试库.资源文件.用例所在文件的关键字表 2 ...
随机推荐
- 一步一步实现视频播放器client(二)
实现主体界面: 222.png (64.46 KB, 下载次数: 0) 下载附件 保存到相冊 前天 21:02 上传 比較常见的一种布局.以下几个button.点击后 ...
- smokeping安装
一.准备工作: 1.以防止安装依赖出错,首先给系统安装第三方源:rpm -Uvh http://apt.sw.be/redhat/el6/en/x86_64/rpmforge/RPMS/rpmforg ...
- hdu2473 Junk-Mail Filter 并查集+删除节点+路径压缩
Description Recognizing junk mails is a tough task. The method used here consists of two steps: 1) ...
- python 基础 4.1 函数的参数
#/usr/bin/python #coding=utf-8 #@Time :2017/10/24 9:09 #@Auther :liuzhenchuan #@File :函数的参数.py # ...
- EasyNVR无插件播放HLS/RTMP网页直播方案前端完善:监听表单变动
在上一篇博客中我们表述完了防止提交成功后多余操作提交的一个过程:其中的精髓在于ajax的触发事件的使用. 而这篇博客主要想说明一下如何实时的判断出表单是否发生变化. 问题表述: 在网页前端的开发过程中 ...
- EasyNVR无插件IPC摄像机直播方案前端构建之:区分页面是自跳转还是分享依据
区分分享还是跳转 对于前端一些页面的展示,通常有两种方式:通过入口链接一步步进入,或是通过分享链接直接进入:对于这两种方式的区别是什么?在进行前端书写时又应该如何处理? 以EasyNVR为例来进行说明 ...
- angularcli填坑系列(持续更新...)
1.在xx.ts中引入css样式无效 @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls ...
- Refused to set unsafe header
Refused to set unsafe header Refused to set unsafe header "Host"waitServerDeal @ tGet.html ...
- 性能测试--yslow
YSlow YSlow可以对网站的页面进行分析,并告诉你为了提高网站性能,如何基于某些规则而进行优化. YSlow可以分析任何网站,并为每一个规则产生一个整体报告,如果页面可以进行优化,则YSlow会 ...
- Kafka核心思想
Kafka是2010年12月份开源的项目,采用Scala语言编写,使用了多种效率优化机制,整体架构比较新颖(push/pull),更适合异构集群. 设计目标: (1) 数据在磁盘上的存取代价为O(1) ...