浅谈标记永久化: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的更多相关文章

  1. 关于《自动化测试实战宝典:Robot Framework + Python从小工到专家》

    受新冠疫情影响,笔者被“困”在湖北老家七十余天,于4月1号(愚人节)这天,终于返回到广州.当前国内疫情基本已趋于平稳,但全球疫情整体势态仍在持续疯涨,累计确诊病例已近80万人.祈祷这场全球性灾难能尽早 ...

  2. 简单介绍下自动化框架:Robot Framework

    一.简介: Robot Framework:Robot Framework是由Python编写的一款功能丰富并且扩展性强的自动化测试框架,也可以在Java和 .NET 上运行. HttpRunner: ...

  3. RobotFramework-RIDE环境搭建二:Robot Framework-RIDE安装过程以及踩雷点

    前期准备工作: Python 2.7(上篇文章中已安装成功) Robot Framework-2.8.5 Robot Framework-RIDE-1.5.2.1 (测试用例的创建.运行可以在图形界面 ...

  4. SPOJ:Robot(数学期望)

    There is a robot on the 2D plane. Robot initially standing on the position (0, 0). Robot can make a ...

  5. POJ 1573:Robot Motion

    Robot Motion Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 11324   Accepted: 5512 Des ...

  6. 一:robot framework环境安装

    1.安装robot framework: 打开cmd进入dos下,输入 pip install robotframework Microsoft Windows [版本 10.0.18362.267] ...

  7. 【bzoj3938】 Robot

    http://www.lydsy.com/JudgeOnline/problem.php?id=3938 (题目链接) 题意 给出数轴上$n$个点,有$m$个操作,在时间$t$让一个点以一定的速度移动 ...

  8. 三:robot framework常用关键字

    该部分介绍的是内置库:Builtin,估不需要导入,即可使用 1.RF中定义一个变量: ${XXX}   XXX表示:变量名 *** Settings *** *** Test Cases *** 定 ...

  9. 二:robot framework基本组成

    1.RF组成:套件.用例.关键字 套件:测试用例的集合,可以是一个模块的功能点的集合.也可以是很多模块功能点的集合 用例:一般是由多个关键字组成的 关键字:测试库.资源文件.用例所在文件的关键字表 2 ...

随机推荐

  1. android开发系列之数据存储

    在我们的android实际开发过程,必不可少的一种行为操作对象就是数据.有些数据,对于用户而言是一次性的,这就要求我们每次进到App的时候,都需要去刷新数据.有些数据,对于用户而言又是具有一定时效性的 ...

  2. JAVA学习第二十五课(多线程(四))- 单例设计模式涉及的多线程问题

    一.多线程下的单例设计模式 利用双重推断的形式解决懒汉式的安全问题和效率问题 //饿汉式 /*class Single { private static final Single t = new Si ...

  3. Xenomai PC开发环境

    这两天总在纠结编译一个PC机上的Xenomai开发环境,选择编译器.kernel版本和IPIP版本,但是今天忽然想到,上位机只是个开发环境,只要能编译.能运行就可以了,实时性根本不是关注的东西.而Xe ...

  4. python升级安装后的yum的修复

    升级python版本号后,执行yum # yum -y install openssl 提演示样例如以下: There was a problem importing one of the Pytho ...

  5. golang 格式化时间成datetime

    Golang或者Beego,总需要往数据库里写datetime时间戳. Golang对时间格式支持并不理想. 先看一个例子: package main import ( "fmt" ...

  6. bugzilla 系列1安装

    安装好mysql yum install gcc perl* mod_perl-devel -y wget https://ftp.mozilla.org/pub/mozilla.org/webtoo ...

  7. 04 redis list结构及命令详解

    一:link 链表结构 lpush key value 作用: 把值插入到链接头部[右边] 注意:rpush key value 插入到左边 rpop key 作用: 返回并删除链表尾元素 rpush ...

  8. 复习Java虚拟机:JVM中的Stack和Heap

    在JVM中,内存分为两个部分,Stack(栈)和Heap(堆).这里,我们从JVM的内存管理原理的角度来认识Stack和Heap,并通过这些原理认清Java中静态方法和静态属性的问题. 一般,JVM的 ...

  9. Error -27728: Step download timeout (120 seconds)的解决方法(转)

    LR中超时问题解决方法 超时错误在LoadRunner录制Web协议脚本回放时超时经常出现. 现象1:Action.c(16): Error -27728: Step download timeout ...

  10. 基于EasyNVR二次开发实现业务需求:直接集成EasyNVR播放页面到自身项目

    EasyNVR着重点是立足于视频能力层,但是自身也是可以作为一个产品使用的.这就更加方便了应用层的使用. 由于业务需求的缘故,无法使用实体项目展示. 案例描述 该业务系统是国内某大型显示屏生产企业内部 ...