[BZOJ 1568][JSOI2008]Blue Mary开公司
[BZOJ 1568][JSOI2008]Blue Mary开公司
题意
\(n\) 次操作, 维护一个一次函数集合 \(S\). 有两种操作:
- 给定 \(b\) 和 \(k\), 向 \(S\) 中插入一个函数 \(f(x)=kx+b\).
- 给定一个 \(x\), 求 \(\max\limits_{f\in S}\{f(x)\}\).
\(n\le 1\times 10^5,x\le 50000\).
题解
AFO前的打板子日常
讲道理为啥一个 \(\log\) 的题数据范围才给这么点啊
李超线段树板子题.
关于李超树
李超线段树是一种特殊的标记永久化线段树. 说它特殊, 是因为标记虽然永久化但是依然会有下传.
在这种线段树中, 每个结点维护的是覆盖当前结点的 "优势线段", 也即当前结点中有超过一半的 \(x\) 的查询值在这个线段处取到. 由于是一次函数, 实际上等价于当前结点的 \(mid\) 处以这个函数为最大函数值.
当插入一个函数 \(f(x)\) 的时候, 分三种情况:
- 如果原来的优势线段 \(g(x)\) 在当前结点所在区间的所有 \(x\) 处都有 \(g(x)\le f(x)\), 那么直接把当前结点的优势线段设为 \(f(x)\) 并结束插入过程.
- 如果 \(\forall x,f(x)\le g(x)\), 那么不进行任何修改, 结束插入过程.
- 如果不满足上面两个条件, 那么判断 \(g(x)\) 和 \(f(x)\) 哪个是优势线段, 并计算出它们的交点. 显然不包含交点的一半子树中 \(f(x)\) 和 \(g(x)\) 的关系如上面两种情况, 但是被淘汰的线段仍然可能在另一个子树中的某个点中成为优势线段, 所以将被淘汰的线段递归处理.
查询的时候就像普通的标记永久化线段树一样查到叶子并用路径上的结点上存储的优势线段更新答案.
不难发现如果维护的是函数集合的话复杂度是一个 \(\log\) 的. 如果是在某一段特定区间上产生一个一次函数状的贡献的话, 会先将这个函数分布到 \(O(\log n)\) 个结点上然后下传, 这种情况下时间复杂度是 \(O(\log^2 n)\) 的.
李超树的实际表现还是很优秀的, 很多时候在区间维护的情况下也不会比普通线段树慢太多.
具体实现的时候善用 std::swap
可以帮助减少冗余代码. 而且交点不用真的去求, 因为是一次函数所以判断区间两端的函数值的大小关系就知道它们是否在这个区间内相交了.
关于这道题
这道坑爹的板子题有几个小坑点:
- 输出的时候需要转单位.
- 初值为 \(0\) (也就是如果唯一的函数在查询的 \(x\) 处为负数的时候应该查得 \(0\)).
- 因为初值是 \(0\) 所以不存在向 \(0\) 取整还是向下取整的问题.
参考代码
#include <bits/stdc++.h>
const int MAXN=1e5+10;
struct Line{
double k;
double b;
Line(double a,double b):k(a),b(b){}
double operator()(const double& x)const{
return k*(x-1)+b;
}
};
struct Node{
int l;
int r;
Line f;
Node* lch;
Node* rch;
Node(int,int);
double Query(int);
void Insert(Line);
};
char buf[100];
int main(){
int q;
bool flag=false;
scanf("%d",&q);
Node* N=new Node(1,5e4);
while(q--){
scanf("%s",buf);
if(*buf=='P'){
flag=true;
double k,b;
scanf("%lf%lf",&b,&k);
N->Insert(Line(k,b));
}
else{
int x;
scanf("%d",&x);
if(!flag)
puts("0");
else
printf("%d\n",int(N->Query(x)/100));
}
}
return 0;
}
double Node::Query(int x){
if(this->l==this->r)
return this->f(x);
else{
if(x<=this->lch->r)
return std::max(this->f(x),this->lch->Query(x));
else
return std::max(this->f(x),this->rch->Query(x));
}
}
void Node::Insert(Line f){
int mid=(this->l+this->r)>>1;
if(f(mid)>this->f(mid))
std::swap(f,this->f);
double ld=this->f(this->l)-f(this->l);
double rd=this->f(this->r)-f(this->r);
if(ld>=0&&rd>=0)
return;
else if(rd>=0)
this->lch->Insert(f);
else
this->rch->Insert(f);
}
Node::Node(int l,int r):l(l),r(r),f(0,0){
if(l!=r){
int mid=(l+r)>>1;
this->lch=new Node(l,mid);
this->rch=new Node(mid+1,r);
}
}
[BZOJ 1568][JSOI2008]Blue Mary开公司的更多相关文章
- 数据结构(线段树):BZOJ 1568 [JSOI2008]Blue Mary开公司
1568: [JSOI2008]Blue Mary开公司 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 602 Solved: 214[Submit ...
- bzoj 1568 [JSOI2008]Blue Mary开公司 超哥线段树
[JSOI2008]Blue Mary开公司 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1808 Solved: 639[Submit][Sta ...
- BZOJ.1568.[JSOI2008]Blue Mary开公司(李超线段树)
题目链接 线段树每个节点记录\(f(mid)\)最大的直线(在\(mid\)处函数值最大的直线),称作优势线段(还是直线啊...无所谓了). 如果是在区间插入线段会影响\(O(\log n)\)个区间 ...
- 1568: [JSOI2008]Blue Mary开公司
1568: [JSOI2008]Blue Mary开公司 题目描述 传送门 题目分析 简单分析可以发现就是不停给出了\(n\)条直线,要求每次给出一条直线后求出所有直线在横坐标为\(x\)时\(y\) ...
- 1568: [JSOI2008]Blue Mary开公司(超哥线段树)
1568: [JSOI2008]Blue Mary开公司 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1198 Solved: 418 Descr ...
- bzoj千题计划219:bzoj1568: [JSOI2008]Blue Mary开公司
http://www.lydsy.com/JudgeOnline/problem.php?id=1568 写多了就觉着水了... #include<cstdio> #include< ...
- 【BZOJ1568】[JSOI2008]Blue Mary开公司(李超线段树)
[BZOJ1568][JSOI2008]Blue Mary开公司(李超线段树) 题面 BZOJ 洛谷 题解 是模板题啊. #include<iostream> #include<cs ...
- 【BZOJ1568】[JSOI2008]Blue Mary开公司 线段树
[BZOJ1568][JSOI2008]Blue Mary开公司 Description Input 第一行 :一个整数N ,表示方案和询问的总数. 接下来N行,每行开头一个单词“Query”或“P ...
- [Luogu] P4254 [JSOI2008]Blue Mary开公司
题目背景 Blue Mary 最近在筹备开一家自己的网络公司.由于他缺乏经济头脑,所以先后聘请了若干个金融顾问为他设计经营方案. 题目描述 万事开头难,经营公司更是如此.开始的收益往往是很低的,不过随 ...
随机推荐
- spring StopWatch用法
背景 有时我们在做开发的时候需要记录每个任务执行时间,或者记录一段代码执行时间,最简单的方法就是打印当前时间与执行完时间的差值,然后这样如果执行大量测试的话就很麻烦,并且不直观,如果想对执行的时间做进 ...
- Spring 通过Java代码装配bean
1. 背景 书接上文Spring自动化装配bean 尽管在很多场景下通过组件扫描和自动装配实现Spring的自动化扫描配置是更为推荐的方式,但在有些情况下自动化扫描的方案行不通,如想要将第三方库中的组 ...
- 线性回归浅谈(Linear Regression)
在现实生活中普遍存在着变量之间的关系,有确定的和非确定的.确定关系指的是变量之间可以使用函数关系式表示,还有一种是属于非确定的(相关),比如人的身高和体重,一样的身高体重是不一样的. 线性 ...
- sip (gb28181)信令交互-视频点播与回播
客户端发起的实时点播消息示范:(请求视频信令与断开视频信息 和 回播基本无差别) .请求视频流 INVITE sip:@ SIP/2.0 Via: SIP/;rport;branch=z9hG4bK2 ...
- JVM学习记录-类加载器
前言 JVM设计团队把类加载阶段中的“通过一个类的全限定名来获取描述此类的二进制字节流”这个动作放到Java虚拟机外面去实现,以便让应用程序自己决定如何去获取所需要的类.实现这个动作的代码模块称为“类 ...
- FFmpeg简易播放器的实现-音视频同步
本文为作者原创,转载请注明出处:https://www.cnblogs.com/leisure_chn/p/10284653.html 基于FFmpeg和SDL实现的简易视频播放器,主要分为读取视频文 ...
- kooboocms遇到的问题
1.工作流:需要在网站的内容设置里启用工作流,然后添加一个工作流,再在内容文件夹里设置工作流属性(经测试,工作流对网络用户才有效,也就是说必须把用户添加到该网站下) 2.网络用户页面bug:在行 1. ...
- [日常] Go语言圣经--示例: 并发的Echo服务
最简单的回声服务器: package main import ( "io" "net" "log" ) func main() { list ...
- Springmvx拦截html出现406解决以及Server Tomcat v8.0 Server at localhost failed to start 问题解决方法
问题是这样的:环境是SSM框架,在配置好的框架里想请求一个html,结果406了,406就是HTTP协议状态码的一种,表示无法使用请求的特性来响应请求的网页.一般指客户端浏览器不接受所请求页面的MIM ...
- 安装apr-1.6.3报错[cannot remove `libtoolT’: No such file or directory]解决方法
发现有这个提示:cannot remove `libtoolT’: No such file or directory , 编辑 configure文件,查找 $RM "$cfgfile&q ...