51nod“省选”模测第二场 C 小朋友的笑话(线段树 set)
题意
Sol
直接拿set维护\(li\)连续段。因为set内的区间互不相交,而且每个线段会被至多加入删除一次,所以复杂度是对的。
#include<bits/stdc++.h>
#define Pair pair<int, int>
#define MP make_pair
#define fi first
#define se second
using namespace std;
const int MAXN = 1e6 + 10, INF = 2147483646;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int N, M, s[MAXN], f[MAXN], ll[MAXN], rr[MAXN];
#define ls k << 1
#define rs k << 1 | 1
void update(int k) {
s[k] = s[ls] + s[rs];
}
void ps(int k, int v) {
if(v == 1) s[k] = rr[k] - ll[k] + 1;
else s[k] = 0;
f[k] = v;
}
void pushdown(int k) {
if(f[k] == -1) return ;
ps(ls, f[k]); ps(rs, f[k]);
f[k] = -1;
}
void Build(int k, int l, int r) {
ll[k] = l; rr[k] = r;
if(l == r) return ;
int mid = l + r >> 1;
Build(ls, l, mid);
Build(rs, mid + 1, r);
}
void Mem(int k, int l, int r, int ql, int qr, int val) {
if(ql > qr) return ;
if(ql <= l && r <= qr) {ps(k, val); return ;}
int mid = l + r >> 1;
pushdown(k);
if(ql <= mid) Mem(ls, l, mid, ql, qr, val);
if(qr > mid) Mem(rs, mid + 1, r, ql, qr, val);
update(k);
}
int Query(int k, int l, int r, int ql, int qr) {
if(ql > qr) return 0;
int ans = 0;
//cout << ans << '\n';
if(ql <= l && r <= qr) return s[k];
int mid = l + r >> 1;
pushdown(k);
if(ql <= mid) ans += Query(ls, l, mid, ql, qr);
if(qr > mid) ans += Query(rs, mid + 1, r, ql, qr);
return ans;
}
set<Pair> S[MAXN];
#define sit set<Pair>::iterator
void Add(int l, int r, int x) {
int pl = l, pr = r;
set<Pair> &s = S[x];
sit it = s.lower_bound(MP(l, r));
Mem(1, 1, N, l, r, 1);
if(it != s.begin()) {
it--;
if(it -> se > r) {
Mem(1, 1, N, max(pl, it -> fi), min(pr, it -> se), 0);
}
if(it -> se >= l ) {
l = min(l, it -> fi); r = max(r, it -> se);
Mem(1, 1, N, max(pl, it -> fi), min(pr, it -> se), 0);
s.erase(it++);
}
}
it = s.lower_bound(MP(l, r));
while((it -> se >= l && it -> se <= r) || (it -> fi >= l && it -> fi <= r)) {
l = min(l, it -> fi); r = max(r, it -> se);
Mem(1, 1, N, max(pl, it -> fi), min(pr, it -> se), 0);
s.erase(it++);
}
s.insert(MP(l, r));
}
signed main() {
// freopen("a.in", "r", stdin);
N = read(); M = read();
Build(1, 1, N);
for(int i = 1; i <= N; i++) S[i].insert(MP(INF, INF));
while(M--) {
int opt = read();
if(opt == 1) {
int xi = read(), val = read(), ki = read();
int l = max(1, xi - ki), r = min(N, xi + ki);
Add(l, r, val);
}
else {
int l = read(), r = read();
printf("%d\n", Query(1, 1, N, l, r));
}
}
return 0;
}
51nod“省选”模测第二场 C 小朋友的笑话(线段树 set)的更多相关文章
- 51nod“省选”模测第二场 B 异或约数和(数论分块)
题意 题目链接 Sol 这题是来搞笑的吧.. 考虑一个数的贡献是\(O(\frac{N}{i})\) 直接数论分块. #include<bits/stdc++.h> #define Pai ...
- 51nod"省选"模测 A 树的双直径(树形dp)
题意 题目链接 Sol 比赛结束后才调出来..不多说啥了,就是因为自己菜. 裸的up-down dp,维护一下一个点上下的直径就行,一开始还想了个假的思路写了半天.. 转移都在代码注释里 毒瘤题目卡空 ...
- HDU-DuoXiao第二场hdu 6315 Naive Operations 线段树
hdu 6315 题意:对于一个数列a,初始为0,每个a[ i ]对应一个b[i],只有在这个数字上加了b[i]次后,a[i]才会+1. 有q次操作,一种是个区间加1,一种是查询a的区间和. 思路:线 ...
- 杭电多校第二场 hdu 6315 Naive Operations 线段树变形
Naive Operations Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 502768/502768 K (Java/Other ...
- 2020牛客暑假多校训练营 第二场 H Happy Triangle set 线段树 分类讨论
LINK:Happy Triangle 这道题很容易. 容易想到 a+b<x a<x<b x<a<b 其中等于的情况在第一个和第三个之中判一下即可. 前面两个容易想到se ...
- 51nod 1766 树上的最远点对 | LCA ST表 线段树 树的直径
51nod 1766 树上的最远点对 | LCA ST表 线段树 树的直径 题面 n个点被n-1条边连接成了一颗树,给出a~b和c~d两个区间,表示点的标号请你求出两个区间内各选一点之间的最大距离,即 ...
- 2019牛客多校第八场 F题 Flowers 计算几何+线段树
2019牛客多校第八场 F题 Flowers 先枚举出三角形内部的点D. 下面所说的旋转没有指明逆时针还是顺时针则是指逆时针旋转. 固定内部点的答案的获取 anti(A)anti(A)anti(A)或 ...
- 2018牛客网暑假ACM多校训练赛(第六场)I Team Rocket 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round6-I.html 题目传送门 - https://www.no ...
- SCNU省选校赛第二场B题题解
今晚的校赛又告一段落啦,终于"开斋"了! AC了两题,还算是满意的,英语还是硬伤. 来看题目吧! B. Array time limit per test 2 seconds me ...
随机推荐
- 【RL-TCPnet网络教程】第22章 RL-TCPnet之网络协议IP
第22章 RL-TCPnet之网络协议IP 本章节为大家讲解IP(Internet Protocol,网络协议),通过前面章节对TCP和UDP的学习,需要大家对IP也有个基础的认识. (本章 ...
- django启动server报错Error: That port is already in use.
这种一般是端口错误,一般是要把端口关掉,这里提供了两种方法. 方法一:直接命令: sudo lsof -t -i tcp:8000 | xargs kill -9 方法二:脚本:名字manage.py ...
- python网络-多线程(22)
一.什么是线程 线程(英语:thread)是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.同一进程中的多条线程将共享该进程中的全部系统资源,一个进程可以有很多线程,每 ...
- Vue中实现一个无限加载列表
参考 https://www.jianshu.com/p/0a3aebd63a14 一个需要判断的地方就是加载中再次触发滚动的时候,不要获取数据. <!DOCTYPE html> < ...
- 002-J2EE-tomcat的配置
在配置之前我们要先下载一个Tomcat,登入以下网址... 下载解压完了之后可以把里面多余的东西删掉,当然也可以选择不删. 还有这里的也是 如果已经有了 classes 和l ib 目录了, 就不用再 ...
- [bzoj4771] 七彩树
题意 给定一棵n个点,每个点带颜色的有根树.点的编号和颜色编号都在1到n,根的编号为1.m次询问,求x子树中与x距离边数不超过k的点中,颜色的种类数目.每个测试点有多组数据. 分析 不妨设1的父亲为0 ...
- 【Spark篇】---SparkStreaming+Kafka的两种模式receiver模式和Direct模式
一.前述 SparkStreamin是流式问题的解决的代表,一般结合kafka使用,所以本文着重讲解sparkStreaming+kafka两种模式. 二.具体 1.Receiver模式 原理图 ...
- 【Spark篇】--Spark中的宽窄依赖和Stage的划分
一.前述 RDD之间有一系列的依赖关系,依赖关系又分为窄依赖和宽依赖. Spark中的Stage其实就是一组并行的任务,任务是一个个的task . 二.具体细节 窄依赖 父RDD和子RDD parti ...
- Python内置函数(31)——id
英文文档: id(object) Return the “identity” of an object. This is an integer which is guaranteed to be un ...
- asp.net core系列 37 WebAPI 使用OpenAPI (swagger)中间件
一.概述 在使用Web API时,对于开发人员来说,了解其各种方法可能是一项挑战.在ASP.NET Core上,Web api 辅助工具介绍二个中间件,包括:Swashbuckle和NSwag .NE ...