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)$棵子树,若与当前点的最优线段不相交,那么取较优的,否则暴力递归子树. 查询时在叶子到根路径上所有点的最优 ...
随机推荐
- 【Java】 Spring依赖注入小试牛刀:编写第一个Spring ApplicationContext Demo
0 Spring的依赖注入大致是这样工作的: 将对象如何构造(ID是什么?是什么类型?给属性设置什么值?给构造函数传入什么值?)写入外部XML文件里.在调用者需要调用某个类时,不自行构造该类的对象, ...
- RethinkDB创始人教你怎样找到创业点子
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemh1YmFpdGlhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- Python学习总结之五 -- 入门函数式编程
函数式编程 最近对Python的学习有些怠慢,最近的学习态度和学习效率确实很不好,目前这种病况正在好转. 今天,我把之前学过的Python中函数式编程简单总结一下,分享给大家,也欢迎并感谢大家提出意见 ...
- Flyweight Design Pattern 共享元设计模式
就是利用一个类来完毕多种任务.不用每次都创建一个新类. 个人认为这个设计模式在C++里面,好像能够就使用一个函数取代,利用重复调用这个函数完毕任务和重复利用这个类,好像几乎相同. 只是既然是一个设计模 ...
- T-SQL简单查询语句(模糊查询)
T-SQL简单查询语句 简单查询: 1.最简单查询(查所有数据) select * from 表名: 注:* 代表所有列 select * from info 2.查询指定列 select code, ...
- 链接数据库代码封装DBDA
<?php class DBDA { public $host = "localhost"; //服务器地址 public $uid = "root"; ...
- EasyPlayerPro(Windows)流媒体播放器开发之框架讲解
EasyPlayerPro for Windows是基于ffmpeg进行开发的全功能播放器,开发过程中参考了很多开源的播放器,诸如vlc和ffplay等,其中最强大的莫过于vlc,但是鉴于vlc框架过 ...
- Spring Boot:Thymeleaf篇
Spring Boot干货系列:(四)Thymeleaf篇http://www.cnblogs.com/zheting/p/6707037.html 前言 Web开发是我们平时开发中至关重要的,这里就 ...
- 用php動態產生各種尺寸的圖片
我的做法是用php動態產生各種尺寸的圖片,例如<img src="img.php?src=a.jpg&width=100&height=200"...< ...
- 添加@ControllerAdvice后报错 Failed to invoke @ExceptionHandler method
首先.单独使用ControllerAdvice 无法正常工作.需要配合@EnableWebMvc 使用. @ControllerAdvice @EnableWebMvc pulbic class Ex ...