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

  1. 【BZOJ3165】[HEOI2013]Segment(李超线段树)

    [BZOJ3165][HEOI2013]Segment(李超线段树) 题面 BZOJ 洛谷 题解 似乎还是模板题QwQ #include<iostream> #include<cst ...

  2. BZOJ3165 & 洛谷4097:[HEOI2013]Segment——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=3165 https://www.luogu.org/problemnew/show/P4097 要求 ...

  3. bzoj 3165: [Heoi2013]Segment 动态凸壳

    3165: [Heoi2013]Segment Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 202  Solved: 89[Submit][Stat ...

  4. 洛谷 P4097 [HEOI2013]Segment 解题报告

    P4097 [HEOI2013]Segment 题目描述 要求在平面直角坐标系下维护两个操作: 在平面上加入一条线段.记第 \(i\) 条被插入的线段的标号为 \(i\) 给定一个数 \(k\),询问 ...

  5. BZOJ 3165: [Heoi2013]Segment

    3165: [Heoi2013]Segment Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 465  Solved: 187[Submit][Sta ...

  6. Bzoj 3165 [Heoi2013]Segment题解

    3165: [Heoi2013]Segment Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 668  Solved: 276[Submit][Sta ...

  7. BZOJ3165[Heoi2013]Segment——李超线段树

    题目描述 要求在平面直角坐标系下维护两个操作: 1.在平面上加入一条线段.记第i条被插入的线段的标号为i. 2.给定一个数k,询问与直线 x = k相交的线段中,交点最靠上的线段的编号. 输入 第一行 ...

  8. 2019.02.11 bzoj3165: [Heoi2013]Segment(线段树)

    传送门 题意简述:要求支持两种操作: 插入一条线段. 询问与直线x=kx=kx=k相交的线段中,交点最靠上的线段的编号. 思路: 直接上李超线段树即可. 代码: #include<bits/st ...

  9. BZOJ3165 : [Heoi2013]Segment

    建立线段树,每个节点维护该区间内的最优线段. 插入线段时,在线段树上分裂成$O(\log n)$棵子树,若与当前点的最优线段不相交,那么取较优的,否则暴力递归子树. 查询时在叶子到根路径上所有点的最优 ...

随机推荐

  1. python学习(五)列表

    #!/usr/bin/python # 列表的学习, 列表的概念不陌生, 就是熟悉一下python中的列表是如何操作的 # 1. 序列的操作 L = [ 123, 'spam', 1.23] # 里面 ...

  2. 过滤XSS的HTMLPurifier使用

    什么是HTMLPurifier? 在php里解决XSS最简单的方法是使用htmlspecialchars转义xml实体,但对于需要使用xml的时候就搏手无策了. HTML Purifier是基于php ...

  3. Mac修改默认python版本

    研究python爬虫,需要用到Beautiful Soup 但是Mac默认的python版本为2.7 自己安装了3.6的版本 import 报错 查找资料: Mac在启动,会先加载系统配置文件(包括~ ...

  4. JAVA使用并行流(ParallelStream)时要注意的一些问题

    https://blog.csdn.net/xuxiaoyinliu/article/details/73040808

  5. 多媒体开发之---live555 分析客户端

    live555的客服端流程:建立任务计划对象--建立环境对象--处理用户输入的参数(RTSP地址)--创建RTSPClient实例--发出DESCRIBE--发出SETUP--发出PLAY--进入Lo ...

  6. windows 10 python 2.7和python3.6共存解决方法和pip安装

    一.首先去python官网将两个版本下载并安装: 然后进入windows的环境变量,检查下面4个变量: 1.C:\Python272.C:\Python27\Scripts3.D:\software\ ...

  7. Windows 驱动入门(二)代码结构

    windows驱动程序基础.转载标明出处:http://blog.csdn.net/ikerpeng/article/details/38777641 windows驱动程序结构: 我想说的是wind ...

  8. 【BZOJ4012】[HNOI2015]开店 动态树分治+二分

    [BZOJ4012][HNOI2015]开店 Description 风见幽香有一个好朋友叫八云紫,她们经常一起看星星看月亮从诗词歌赋谈到人生哲学.最近她们灵机一动,打算在幻想乡开一家小店来做生意赚点 ...

  9. about gnu bash shell

    1 定义字符串不需要引号 var=NONE echo $var ==>NONE 2 支持基本的整数计算 a=1 b=2 echo $((a+b)) ==>3 必须用$(()),双括号的形式 ...

  10. 小程序的生命周期 launchApp

    https://developers.weixin.qq.com/miniprogram/dev/api/launchApp.html?search-key=生命周期 launchApp(OBJECT ...