BZOJ3165:[HEOI2013]Segment
浅谈标记永久化:https://www.cnblogs.com/AKMer/p/10137227.html
题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=3165
跟这题一样:https://www.cnblogs.com/AKMer/p/10138264.html
不过需要线段完全覆盖当前区间才能递归去替换标记。
时间复杂度:\(O(nlog^2n)\)
空间复杂度:\(O(n)\)
代码如下:
#include <cstdio>
#include <algorithm>
using namespace std;
const int maxn=1e5+5,maxlen=4e4+4,pps=39989;
int n,lstans,cnt;
double b[maxn],k[maxn];
inline 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;
}
inline double calc(int id,int x) {
return k[id]*x+b[id];
}
inline bool check(int id1,int id2,int x) {
double A=k[id1]*x+b[id1],B=k[id2]*x+b[id2];
if(A!=B)return A<B;
return id1>id2;
}
struct segment_tree {
int tag[maxlen<<2];
int query(int p,int l,int r,int pos) {
if(l==r)return tag[p];
int mid=(l+r)>>1;int res;
if(pos<=mid)res=query(p<<1,l,mid,pos);
else res=query(p<<1|1,mid+1,r,pos);
if(check(tag[p],res,pos))return res;
return tag[p];
}
void change_tag(int p,int l,int r,int id) {
if(l==r) {if(check(tag[p],id,l))tag[p]=id;return;}
int mid=(l+r)>>1;
if(k[id]>k[tag[p]]) {
if(check(tag[p],id,mid))change_tag(p<<1,l,mid,tag[p]),tag[p]=id;
else change_tag(p<<1|1,mid+1,r,id);
}
else {
if(check(tag[p],id,mid))change_tag(p<<1|1,mid+1,r,tag[p]),tag[p]=id;
else change_tag(p<<1,l,mid,id);
}
}
void change(int p,int l,int r,int L,int R) {
if(L<=l&&r<=R) {change_tag(p,l,r,cnt);return;}
int mid=(l+r)>>1;
if(L<=mid)change(p<<1,l,mid,L,R);
if(R>mid)change(p<<1|1,mid+1,r,L,R);
}
}T;
inline int fakein(int p) {
int x=read();
return (x+lstans-1)%p+1;
}
inline void make(int id,int x0,int y0,int x1,int y1) {
if(x0==x1)k[id]=0,b[id]=max(y1,y0);
else {
k[id]=1.0*(y1-y0)/(x1-x0);
b[id]=1.0*y0-k[id]*x0;
}
}
int main() {
n=read();
for(int i=1;i<=n;i++) {
int opt=read();
if(opt==0) {
int k=fakein(pps);
lstans=T.query(1,1,pps,k);
printf("%d\n",lstans);
}
else {
int x0=fakein(pps),y0=fakein(1e9),x1=fakein(pps),y1=fakein(1e9);
if(x0>x1)swap(x1,x0),swap(y0,y1);
make(++cnt,x0,y0,x1,y1);
T.change(1,1,pps,x0,x1);
}
}
return 0;
}
BZOJ3165:[HEOI2013]Segment的更多相关文章
- 【BZOJ3165】[HEOI2013]Segment(李超线段树)
[BZOJ3165][HEOI2013]Segment(李超线段树) 题面 BZOJ 洛谷 题解 似乎还是模板题QwQ #include<iostream> #include<cst ...
- BZOJ3165 & 洛谷4097:[HEOI2013]Segment——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=3165 https://www.luogu.org/problemnew/show/P4097 要求 ...
- bzoj 3165: [Heoi2013]Segment 动态凸壳
3165: [Heoi2013]Segment Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 202 Solved: 89[Submit][Stat ...
- 洛谷 P4097 [HEOI2013]Segment 解题报告
P4097 [HEOI2013]Segment 题目描述 要求在平面直角坐标系下维护两个操作: 在平面上加入一条线段.记第 \(i\) 条被插入的线段的标号为 \(i\) 给定一个数 \(k\),询问 ...
- BZOJ 3165: [Heoi2013]Segment
3165: [Heoi2013]Segment Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 465 Solved: 187[Submit][Sta ...
- Bzoj 3165 [Heoi2013]Segment题解
3165: [Heoi2013]Segment Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 668 Solved: 276[Submit][Sta ...
- BZOJ3165[Heoi2013]Segment——李超线段树
题目描述 要求在平面直角坐标系下维护两个操作: 1.在平面上加入一条线段.记第i条被插入的线段的标号为i. 2.给定一个数k,询问与直线 x = k相交的线段中,交点最靠上的线段的编号. 输入 第一行 ...
- 2019.02.11 bzoj3165: [Heoi2013]Segment(线段树)
传送门 题意简述:要求支持两种操作: 插入一条线段. 询问与直线x=kx=kx=k相交的线段中,交点最靠上的线段的编号. 思路: 直接上李超线段树即可. 代码: #include<bits/st ...
- BZOJ3165 : [Heoi2013]Segment
建立线段树,每个节点维护该区间内的最优线段. 插入线段时,在线段树上分裂成$O(\log n)$棵子树,若与当前点的最优线段不相交,那么取较优的,否则暴力递归子树. 查询时在叶子到根路径上所有点的最优 ...
随机推荐
- oracle 误删数据的回复操作
update operator t set t.username = (select username from operator AS OF TIMESTAMP TO_TIMESTAMP('201 ...
- UVA 10428 - The Roots(牛顿迭代法)
UVA 10428 - The Roots option=com_onlinejudge&Itemid=8&page=show_problem&category=494& ...
- DBUtils使用详解
https://blog.csdn.net/samjustin1/article/details/52220423 https://www.cnblogs.com/CQY1183344265/p/58 ...
- C# 自定义控件制作和使用实例(winform)(转)
本例是制作一个简单的自定义控件,然后用一个简单的测试程序,对于初学者来说,本例子比较简单,只能起到抛石引玉的效果. 我也是在学习当中,今后会将自己所学的逐步写出来和大家交流共享. 第一步:新建一个 ...
- iOS 转场动画核心内容
CATransition——转场动画 CATransition是CAAnimation的子类,用于做转场动画,能够为层提供移出屏幕和移入屏幕的动画效果.iOS比Mac OS X的转场动画效果少一点. ...
- X86/X64处理器体系结构及寻址模式
由8086/8088.x86.Pentium发展到core系列短短40多年间,处理器的时钟频率差点儿已接近极限.尽管如此,自从86年Intel推出386至今除了添加一些有关流媒体的指令如mmx/sse ...
- imagecopyresampled()改变图片大小后质量要比imagecopyresized()高。
php程序中改变图片大小的函数大多数人都想到用imagecopyresized(),不过经过测试比较发现,使用imagecopyresampled()改变的图片质量更高. 下面我们来看看两者的比较结果 ...
- 20170326 ABAP调用外部webservice 问题
1.SE80 创建企业服务: 代理生成:出现错误 库处理程序中出现例外 错误的值:未知类型参考ns1:ArrayOfMLMatnrResource 尝试: 一.测试本地文件:---无效 1. 将网址链 ...
- ABAP div / mod的用法
1.divdiv是用于取两数相除的商的,c = a div b,得到的c的值就是a除b的商.2.// 是用于取两数相除的结果的.c = a / b,如果c是i数据类型的,这个语法会进行四舍五入的.3. ...
- Git core objects
Git core objects Core objects in git blob object tree object commit object Git low level commands gi ...