题面

题解

李超线段树

为了与机房大佬 HYJ 同步伐

学习笔记请移步 yyb的博客

Code

#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
#include <cmath>
const int N = 100005;
const int mod = 39989;
#define val(id, x) (k[id] * x + b[id])
using namespace std; int Q, cnt, ans;
struct node
{
int id;
double k, b;
} t[N << 2];
double k[N], b[N]; template < typename T >
inline T read()
{
T x = 0, w = 1; char c = getchar();
while(c < '0' || c > '9') { if(c == '-') w = -1; c = getchar(); }
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * w;
} void pushtag(int p, int l, int r, int id)
{
if(!t[p].id) { t[p] = (node) { id, k[id], b[id] }; return; }
int now = t[p].id;
double l1 = val(now, l), r1 = val(now, r), l2 = val(id, l), r2 = val(id, r);
if(l2 <= l1 && r2 <= r1) return;
if(l1 < l2 && r1 < r2) { t[p] = (node) { id, k[id], b[id] }; return; }
int mid = (l + r) >> 1; double x = (b[id] - b[now]) / (k[now] - k[id]);
if(x <= mid)
{
if(l1 <= l2) pushtag(p << 1, l, mid, id);
else pushtag(p << 1, l, mid, now), t[p] = (node) { id, k[id], b[id] };
}
else
{
if(l1 <= l2) pushtag(p << 1 | 1, mid + 1, r, now), t[p] = (node) { id, k[id], b[id] };
else pushtag(p << 1 | 1, mid + 1, r, id);
}
} void modify(int p, int l, int r, int ql, int qr, int id)
{
if(ql <= l && r <= qr) { pushtag(p, l, r, id); return; }
int mid = (l + r) >> 1;
if(ql <= mid) modify(p << 1, l, mid, ql, qr, id);
if(mid < qr) modify(p << 1 | 1, mid + 1, r, ql, qr, id);
} void check(int &a, int c, int x)
{
double y0 = val(a, x), y1 = val(c, x);
if(y1 > y0 || (fabs(y1 - y0) < 1e-7 && a > c)) a = c;
} int query(int p, int l, int r, int x)
{
if(l == r) return t[p].id;
int mid = (l + r) >> 1, res = t[p].id;
if(x <= mid) check(res, query(p << 1, l, mid, x), x);
else check(res, query(p << 1 | 1, mid + 1, r, x), x);
return res;
} int main()
{
/* freopen("cpp.in", "r", stdin);
freopen("cpp.out", "w", stdout);
*/ Q = read <int> ();
int opt, x0, x1, y0, y1;
while(Q--)
{
opt = read <int> ();
if(!opt)
{
// printf("%d\n", x0);
x0 = read <int> (), x0 = ((x0 + ans - 1) % mod + 1);
printf("%d\n", ans = query(1, 1, mod, x0));
}
else
{
x0 = read <int> (), y0 = read <int> (), x1 = read <int> (), y1 = read <int> ();
x0 = ((x0 + ans - 1) % mod + 1), y0 = ((y0 + ans - 1) % 1000000000 + 1);
x1 = ((x1 + ans - 1) % mod + 1), y1 = ((y1 + ans - 1) % 1000000000 + 1);
if(x0 > x1) swap(x0, x1), swap(y0, y1);
// printf("%d %d\n", x0, x1);
k[++cnt] = 1.0 * (y1 - y0) / (x1 - x0), b[cnt] = 1.0 * y0 - k[cnt] * x0;
modify(1, 1, mod, x0, x1, cnt);
}
}
return 0;
}
/*
3
1 3 5 7 7
1 3 9 7 3
0 5
*/

[题解] [HEOI2013] Segment的更多相关文章

  1. Bzoj 3165 [Heoi2013]Segment题解

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

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

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

  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. 【题解】Luogu P4097 [HEOI2013]Segment

    原题传送门 这珂以说是李超线段树的模板题 按着题意写就行了,时间复杂度为\(O(n\log^2n)\) #include <bits/stdc++.h> #define N 40005 # ...

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

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

  8. HEOI2013 Segment

    传说中的“李超树”. 大意:给你若干线段,试求横坐标x上的最上方一条线段的编号.无则输出零. 解:用线段树维护. 插入的时候保存自己这个区间上可能成为最大值的线段,被抛弃的则看情况下放. 查询时从最底 ...

  9. 洛谷P4097 [HEOI2013]Segment(李超线段树)

    题面 传送门 题解 调得咱自闭了-- 不难发现这就是个李超线段树,不过因为这里加入的是线段而不是直线,所以得把线段在线段树上对应区间内拆开之后再执行李超线段树的操作,那么复杂度就是\(O(n\log^ ...

随机推荐

  1. Nginx实现同一端口HTTP跳转HTTPS

    小目标:在只监听一个端口的情况下,将http访问跳转为https. 一般情况下http协议使用80端口,https协议443端口.要实现http强制转https是非常简单的事,随便都可以找到很多方案. ...

  2. pytorch自定义网络层以及损失函数

    转自:https://blog.csdn.net/dss_dssssd/article/details/82977170 https://blog.csdn.net/dss_dssssd/articl ...

  3. Vue页面手动刷新,导航栏激活项还原到初始状态问题解决方案

    场景描述:在页面中存在顶部导航和左侧导航,左侧导航和右侧内容区使用了命名视图实现,点击左侧导航的链接时,右侧内容区相应显示不同组件内容.问题:在当前链接手动刷新浏览器(例如:浏览器地址为/enterp ...

  4. 如何在vscode中调试vue-cli项目?

    一:参考官网文档,写的还是很清楚的:https://cn.vuejs.org/v2/cookbook/debugging-in-vscode.html 二:需要安装的东西和初始项目 2.1  用vue ...

  5. nodejs入门API之url模块+querystring模块

    关于URL的一些基础内容 URL模块的API解析 URL的参数URLSearchParams类 querystring模块 一.关于URL的一些基础内容 1.1 定义: 在WWW上,每一信息资源都有统 ...

  6. 使用Canvas压缩图片

    讲干货,不啰嗦,当涉及对图片有质量压缩要求的时候,可以使用Canvas实现图片压缩. 步骤: 1.获取img元素,既要压缩的图片 2.创建canvas对象 3.使用canvas的drawImage方法 ...

  7. SQL将同样标识的查询结果查重并用逗号拼接

    SELECT B.TaskID , LEFT(SamList, LEN(SamList) - 1) AS ResultListFROM ( SELECT TaskID , ( SELECT Sampl ...

  8. C语言对齐、补齐

    加快CPU读取数据的速度 aligned(n) 让所作用的结构成员对齐在n字节自然边界上.如果结构中有成员的长度大于n,则按照最大成员的长度来对齐 struct s { char c; int i; ...

  9. 6.NIO2-Path、Paths、Files

    NIO.2 jdk1.7中,java对 NIO 极大的扩展,主要增强的是对文件处理 和 文件系统特性的支持 关于其中一些API的使用 public class TestNIO_2_Path_File ...

  10. 页面Header自适应屏幕

    <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...