#6034. 「雅礼集训 2017 Day2」线段游戏 李超树
#6034. 「雅礼集训 2017 Day2」线段游戏
题目描述
给出若干条线段,用 (x1,y2),(x2,y2) (x_1, y_2), (x_2, y_2)(x1,y2),(x2,y2) 表示其两端点坐标,现在要求支持两种操作:
0 x1 y1 x2 y2表示加入一条新的线段 (x1,y2),(x2,y2) (x_1, y_2), (x_2, y_2)(x1,y2),(x2,y2);1 x0询问所有线段中,x xx 坐标在 x0 x_0x0 处的最高点的 y yy 坐标是什么,如果对应位置没有线段,则输出 0 00。
输入格式
第一行两个正整数 n nn、m mm 为初始的线段个数和操作个数。
接下来 n nn 行,每行四个整数,表示一条线段。
接下来 m mm 行,每行为一个操作 0 x1 y1 x2 y2 或 1 x0。
输出格式
对于每一个询问操作,输出一行,为一个实数,当你的答案与标准答案误差不超过 10−2 10 ^ {-2}10−2 时,则视为正确。
样例
样例输入
3 4
0 -1 4 1
4 2 7 2
7 1 8 2
1 4
1 3
0 3 3 6 3
1 3
样例输出
2
0.5
3
对于线段树的每个节点,维护每个节点使得mid的值最大。
对于不优的答案下传。查询时与标记永久化的查询类似。
其实就是李超树。
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<algorithm>
#define maxn 100005
using namespace std;
inline int read() {
int x=,f=;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-;
for(;isdigit(ch);ch=getchar()) x=x*+ch-'';
return x*f;
}
struct seg {double k,b;seg(){b=-;}}t[maxn*];
inline double cal(seg now,int x) {return now.k*x+now.b;}
inline void work(int l,int r,int o,seg x) {
if(cal(t[o],l)>=cal(x,l)&&cal(t[o],r)>=cal(x,r)) {return;}
if(cal(t[o],l)<cal(x,l)&&cal(t[o],r)<cal(x,r)) {t[o]=x;return;}
int mid=(l+r)>>,ls=o<<,rs=ls+;
if(cal(t[o],l)>=cal(x,l)&&cal(t[o],mid)<cal(x,mid)) {
seg tmp=t[o];t[o]=x;
work(l,mid,ls,tmp);
return;
}
if(cal(t[o],l)>=cal(x,l)&&cal(t[o],mid)>cal(x,mid)) {
if(l!=r) work(mid+,r,rs,x);
return;
}
if(cal(t[o],l)<cal(x,l)&&cal(t[o],mid)<cal(x,mid)) {
seg tmp=t[o];t[o]=x;
if(l!=r) work(mid+,r,rs,tmp);
return;
}
if(cal(t[o],l)<cal(x,l)&&cal(t[o],mid)>=cal(x,mid)) {
if(l!=r) work(l,mid,ls,x);
return;
}
}
inline void update(int l,int r,int o,int L,int R,seg x) {
// cout<<l<<' '<<r<<endl;
if(L<=l&&R>=r) {work(l,r,o,x);return;}
int mid=(l+r)>>,ls=o<<,rs=ls+;
if(L<=mid) update(l,mid,ls,L,R,x);
if(R>mid) update(mid+,r,rs,L,R,x);
}
double ans;
inline double query(int l,int r,int o,int x) {
if(l==r) return cal(t[o],l);
int mid=(l+r)>>,ls=o<<,rs=ls+;
if(x<=mid) return ans=max(ans,max(cal(t[o],x),query(l,mid,ls,x)));
else return ans=max(ans,max(cal(t[o],x),query(mid+,r,rs,x)));
}
int n,m;
int main() {
n=read(),m=read();
for(int i=;i<=n;i++) {
int x1=read(),y1=read(),x2=read(),y2=read();
if(x1>x2) {swap(x1,x2);swap(y1,y2);}
if(x2<||x1>) continue;
seg x;
if(x1==x2) x.k=,x.b=max(y1,y2);
else {
x.k=(double)(y2-y1)/(double)(x2-x1);
x.b=y1-x.k*x1;
}
update(,,,max(,x1),min(,x2),x);
}
while(m--) {
int tp=read();
if(tp==) {
int x1=read(),y1=read(),x2=read(),y2=read();
if(x1>x2) {swap(x1,x2);swap(y1,y2);}
if(x2<||x1>) continue;
seg x;
if(x1==x2) x.k=,x.b=max(y1,y2);
else {
x.k=(double)(y2-y1)/(double)(x2-x1);
x.b=y1-x.k*x1;
}
update(,,,max(,x1),min(,x2),x);
}
else {
int x=read();ans=-;
query(,,,x);
printf("%.3lf\n",ans==-?:ans);
}
}
}
#6034. 「雅礼集训 2017 Day2」线段游戏 李超树的更多相关文章
- loj#6034 「雅礼集训 2017 Day2」线段游戏
分析 区间李超树板子题 代码 #include<bits/stdc++.h> using namespace std; #define db double const int inf = ...
- 【loj6034】「雅礼集训 2017 Day2」线段游戏
#6034. 「雅礼集训 2017 Day2」线段游戏 内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:Special Judge 上传者: 匿名 题目描述 ...
- 「雅礼集训 2017 Day2」线段游戏(线段树懒标记“启发式下传”,李超树)
题面 题解 加入一条线段,可以把它转化为在[L,R]区间内加一条线 y=ax+b (如果原线段与y轴平行,就相当于在{x1}处加一条线 y=max(y1,y2)) 我们可以把它加到线段树上,线段树上每 ...
- 「雅礼集训 2017 Day2」解题报告
「雅礼集训 2017 Day2」水箱 我怎么知道这种题目都能构造树形结构. 根据高度构造一棵树,在树上倍增找到最大的小于约束条件高度的隔板,开一个 \(vector\) 记录一下,然后对于每个 \(v ...
- loj#6033. 「雅礼集训 2017 Day2」棋盘游戏(二分图博弈)
题意 链接 Sol 第一次做在二分图上博弈的题..感觉思路真是清奇.. 首先将图黑白染色. 对于某个点,若它一定在最大匹配上,那么Bob必胜.因为Bob可以一直沿着匹配边都,Alice只能走非匹配边. ...
- loj#6032. 「雅礼集训 2017 Day2」水箱(并查集 贪心 扫描线)
题意 链接 Sol 神仙题+神仙做法%%%%%%%% 我再来复述一遍.. 首先按照\(y\)坐标排序,然后维护一个扫描线从低处往高处考虑. 一个连通块的内状态使用两个变量即可维护\(ans\)表示联通 ...
- [LOJ#6033]. 「雅礼集训 2017 Day2」棋盘游戏[二分图博弈、匈牙利算法]
题意 题目链接 分析 二分图博弈经典模型,首先将棋盘二分图染色. 考虑在某个最大匹配中: 如果存在完美匹配则先手必败,因为先手选定的任何一个起点都在完美匹配中,而后手则只需要走这个点的匹配点,然后先手 ...
- LOJ#6032. 「雅礼集训 2017 Day2」水箱
传送门 首先可以有一个平方复杂度的 \(DP\) 设 \(f_{i,j}\) 表示前面 \(i\) 个小格,高度为 \(j\) 的最大答案 令 \(h_i\) 表示隔板 \(i\) 的高度 当 \(j ...
- 「雅礼集训 2017 Day2」水箱
题目链接 题意分析 我们用\(f[i][j]\)表示当前到达第\(i\)个位置水位高度为\(j\)的答案 如果那么\(h[i]\)为\(i\)和\(i+1\)之间的支柱高度 那么如果\(j≤h[i]\ ...
随机推荐
- Promise使用手册
导读 Promise问世已久, 其科普类文章亦不计其数. 遂本篇初衷不为科普, 只为能够温故而知新. 比如说, catch能捕获所有的错误吗? 为什么有些时候会抛出"Uncaught (in ...
- 关于php网络爬虫phpspider
前几天,被老板拉去说要我去抓取大众点评某家店的数据,当然被我义正言辞的拒绝了,理由是我不会...但我的反抗并没有什么卵用,所以还是乖乖去查资料,因为我是从事php工作的,首先找的就是php的网络爬虫源 ...
- 一个类似植物大战僵尸的python源码
# 1 - Import library import pygame from pygame.locals import * import math import random # 2 - Initi ...
- [luogu P1442] 铁球落地
题目链接 线段树\(+dp\). 先用线段树预处理出每个线段从左边和右边掉落到哪里,记为\(f[i][0/1]\). 然后记\(g[i][0/1]\)为到达第\(i\)个线段的左边或右边所要的最小时间 ...
- Java操作Redis存储对象类型数据
背景描述 关于JAVA去操作Redis时,如何存储一个对象的数据,大家是非常关心的问题,虽然官方提供了存储String,List,Set等等类型,但并不满足我们现在实际应用.存储一个对象是是 ...
- [Leetcode] Populating next right pointer in each node 填充每个节点的右指针
Given a binary tree struct TreeLinkNode { TreeLinkNode *left; TreeLinkNode *right; TreeLinkNode *nex ...
- linux管理(二)---网络使用情况的监控
我们经常在监控服务器或者排查程序性能瓶颈时需要知道 网络带宽的使用情况,看看带宽是不是瓶颈. linux系统中监控网络的工具和命令很多. 但其实主要分2种,一种是实时监控带宽情况(速度如何),一种是 ...
- Mysql History list length 值太大引起的问题
1. 环境 Mysql 主从 Mysql版本:5.1.49-log 系统:Red Hat Enterprise Linux Server release 5.4 64bit 2. 表面现象 数据库操 ...
- Codeforces Round #350 (Div. 2) B
B. Game of Robots time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- PRINT_TABLE 列以行形式显示
在sqlplus,如果列比较多,往往会显示不够清晰,这时如果能把查询语句行转列就明了多了,在网上看到print_table存储过程:里面所设置的日期格式,可根据自己习惯修改 CREATE OR REP ...