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

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

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

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

但是直接这样做的话时空复杂度都是 \(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. war3 Game

    转载请注明来源:https://www.cnblogs.com/hookjc/ //位置结构.x,y不多说,unknown是3F800000.浮点数1.0?? struct Pos {   DWORD ...

  2. 前端-Data URI Scheme

    了解Data URI scheme,首要要掌握一些URI.URL的基本知识,很多做移动端上开发的同学对这两个基本概念掌握的不够,本文首先会对这两个基本概念做一些简单的介绍. 基本概念 <HTTP ...

  3. MySQL基本命令操作及数据库基本概念

    MySQL基本命令操作及数据库基本概念 1.数据库的基本概念 2.主流数据库介绍 3.关系型非关系型数据库介绍 4.Mysql 安装方法 5.Mysql 基本操作命令 1.数据库的基本概念: 数据库的 ...

  4. 配置docker的DNS

    方式一:在宿主机的 /etc/docker/daemon.json 文件中增加以下内容来设置全部容器的 DNS: { "dns" : [ "114.114.114.114 ...

  5. 磁盘管理+三剑客之awk

    目录 磁盘管理+三剑客之awk 一.磁盘管理 二.格式化命令awk 1.awk的语法 2.参数 3.awk的生命周期 4.awk中的预定义变量 5.awk处理规则的执行流程 6.awk中的函数 7.a ...

  6. 看SparkSql如何支撑企业数仓

    企业级数仓架构设计与选型的时候需要从开发的便利性.生态.解耦程度.性能. 安全这几个纬度思考.本文作者:惊帆 来自于数据平台 EMR 团队 前言 Apache Hive 经过多年的发展,目前基本已经成 ...

  7. React Native纯干货总结

    随着项目也渐渐到了尾声,之前的项目是mobile开发,采用的是React Native.为即将要开始做RN项目或者已经做过的小伙伴可以参考借鉴,也顺便自己做一下之前项目的总结. 文章比较长,可以选择自 ...

  8. VUE项目二级菜单刷新时404 nginx

    原因:vue项目的路径时虚拟路径,并不存在,所以用nginx去请求请求不到,所以vue项目做了两部调整: 1.所有的请求后端接口地址前端写死 2.nginx里把所有的接口转发后端删掉,并添加以下内容 ...

  9. [自动化]基于kolla-ansible部署的openstack自动化巡检生成xlsx报告

    自动化巡检介绍 此巡检项目在kolla-ansible部署的openstack环境上开发,利用ansible-playbook编排的功能,对巡检的任务进行编排和数据处理.主要巡检的对象有IaaS平台和 ...

  10. 思迈特软件Smartbi:专注BI,把产品打造到极致

    在企业服务领域,现在的BI(商业智能)无疑是妥妥的风口.不过在20多年前,BI却完全是一幅门庭冷清宾客稀的光景--小型企业高攀不起,大型企业爱答不理. 一些管理者们理所当然地认为,商业是人脑的高阶竞争 ...