首先题意中的有撤销操作,直接李超树肯定不行,题目允许离线,所以考虑线段树分治

所以问题就变成了求一次函数最大值

这不是李超树板子吗???

然后可以对每个节点都建立动态开点李超树,查询的时候直接从叶子节点跳到根节点就好了

但是直接这样做的话时空复杂度都是 \(O(n\log n\log V)\) 的,空降将近 1.2GB,会被直接卡掉

优化就是,只保留目前节点到根节点的节点的李超树(因为只有这些用得上),然后在 \(O(\log n)\) 个李超树中查询,空间复杂度就变成了 \(O(n\log V)\)。如果想跑得快一点儿的话可以把李超树可持久化,虽然说复杂度仍然是 \(O(n\log n\log V)\) 的。

不过我倒是可持久化了,感觉码量都差不多(

吐槽一下,为啥李超树的效率和维护凸包的效率差不多啊(

#include<algorithm>
#include<cstdio>
#include<vector>
typedef long long ll;
const int M=3e5+5,V=1e9;
const ll INF=0x7fffffffffffffff;
int n,tot,root,k[M],opt[M],t[M*50],chi[M*50][2];ll ans[M];
std::vector<int>id[M<<2];
struct line{
int k,b;
line(const int&x=0,const int&y=0):k(k),b(b){}
inline ll get(const int&x)const{
return 1ll*k*x+b;
}
}p[M];
inline void swap(int&a,int&b){
int c=a;a=b;b=c;
}
inline ll max(const ll&a,const ll&b){
return a>b?a:b;
}
int Modify(int u,int id,int L=0,int R=V*2){
if(!u)return t[++tot]=id,tot;
int mid=(1ll*L+R)*.5,now=++tot;
t[now]=t[u];chi[now][0]=chi[u][0];chi[now][1]=chi[u][1];
if(p[id].get(mid-V)>p[t[now]].get(mid-V))swap(id,t[now]);
if(p[t[now]].get(L-V)>p[id].get(L-V)&&p[t[now]].get(R-V)>p[id].get(R-V))return now;
if(p[id].get(L-V)>p[t[now]].get(L-V))return chi[now][0]=Modify(chi[u][0],id,L,mid),now;
else return chi[now][1]=Modify(chi[u][1],id,mid+1,R),now;
}
ll Query(int u,int x,int L=0,int R=V*2){
if(!u)return-INF;
if(L==R)return p[t[u]].get(x-V);
int mid=(1ll*L+R)*.5;
if(x<=mid)return max(p[t[u]].get(x-V),Query(chi[u][0],x,L,mid));
else return max(p[t[u]].get(x-V),Query(chi[u][1],x,mid+1,R));
}
void modify(int u,int d,int l,int r,int L=1,int R=n){
if(l>R||L>r)return;
if(l<=L&&R<=r)return id[u].push_back(d);
int mid=L+R>>1;
modify(u<<1,d,l,r,L,mid);modify(u<<1|1,d,l,r,mid+1,R);
}
void Solve(int u=1,int L=1,int R=n){
int lroot=root,ltot=tot;
for(int&L:id[u])root=Modify(root,L);
if(L<R){
int mid=L+R>>1;
Solve(u<<1,L,mid);Solve(u<<1|1,mid+1,R);
}
else if(opt[L]==3)ans[L]=root?Query(root,k[L]+V):-INF;
while(tot>ltot)chi[tot][0]=chi[tot][1]=t[tot]=0,--tot;root=lroot;
}
signed main(){
register int i;
scanf("%d",&n);
for(i=1;i<=n;++i){
scanf("%d",opt+i);
if(opt[i]==1)scanf("%d%d",&p[i].k,&p[i].b),k[i]=n;
if(opt[i]==2)scanf("%d",k+i),k[k[i]]=i;
if(opt[i]==3)scanf("%d",k+i);
}
for(i=1;i<=n;++i)if(opt[i]==1)modify(1,i,i,k[i]);
Solve();
for(i=1;i<=n;++i){
if(opt[i]==3){
if(ans[i]==-INF)printf("EMPTY SET\n");
else printf("%lld\n",ans[i]);
}
}
}

CF678F题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. ImageMagick转换图片格式

    /usr/bin/convert data/manager/tongji/Html/WebData/images/code0/xingfumima0_1000_0.jpg -colorspace cm ...

  2. iOS应用性能调优--初级---王朋

    目录 我要给出的建议将分为三个不同的等级: 入门级. 中级和进阶级: 入门级(这是些你一定会经常用在你app开发中的建议) 1. 用ARC管理内存 2. 在正确的地方使用reuseIdentifier ...

  3. 简单仿京东"筛选"界面 双导航栏控制器共存 by Nicky.Tsui

    大概就是这么一个效果 如图.大概可以看到,"筛选"视图后面有一层视图盖住了后面原来的视图 那么我们可以通过加一个view到导航栏控制器的view里面来实现 //该view作为全局变 ...

  4. C++奇异递归模板模式

    虚函数的问题 虚函数的主要问题是性能开销比较大,一个虚函数调用可能需要花费数倍于非虚函数调用的时间,尤其是当非虚函数被声明为inline时(注意,虚函数不能被内联). CRTP介绍 CRTP的全称是C ...

  5. 手把手教你把 Git 子模块更新到主项目

    本文以 skywalking-rocketbot-ui子模块合并到 skywalking 为例,手把手教你如何把 Git 子模块更新到主项目中去. 首先,把fork的skywalking项目克隆到本地 ...

  6. 【Kotlin】初识Kotlin(二)

    [Kotlin]初识Kotlin(二) 1.Kotlin的流程控制 流程控制是一门语言中最重要的部分之一,从最经典的if...else...,到之后的switch,再到循环控制的for循环和while ...

  7. FastDFS安装和简介详细总结

    1.fastDFS简介 1 FastDFS是用c语言编写的一款开源的分布式文件系统. 2 FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高性能等指标, 3 ...

  8. vscode打开多个文件

    vscode短时间内打开多个文件会覆盖原先打开的文件,在右方编辑区只显示一个.若想每次打开,都新创建一个编辑,可以用以下2个简单的方法: 方法一:直接在右侧打开的文件上,Ctrl + S,保存一次,再 ...

  9. c++隐式类型转换存在的陷阱

    目录 目标代码 构造函数定义的隐式类型转换 分析a1 分析a2 分析a3 目标代码 旨在弄懂下面的代码,明确变量a1,a2,a3在创建时编译器究竟干了那些事: #include<iostream ...

  10. [旧][Android] ButterKnife 浅析

    备注 原发表于2016.05.08,资料已过时,仅作备份,谨慎参考 前言 自上星期写 Retrofit 写吐之后 ... 我问大队长能不能换个其他什么东西写,大队长就说了个单词 ButterKnife ...