CF915E 动态开线段树
CF915E 动态开线段树
因为\(n\le10^9\),所以动态开点,线段树维护\([1,n]\)天非工作日数量。
之前的结构体写法被卡了,只能改成函数传l,r(虽然也不难)
动态开点好写,但是太菜了线段树部分写炸了,对lazy标记理解不深,下放标记时注意不要把本来子区间的信息覆盖了,下放完标记后要把标记复原。
#include <cstdio>
#define MAXN 15001000
#define mid ((xl+xr)>>1)
using namespace std;
int n,q;
int tot;
struct nod{
int sl,sr,val;
int lazy;
} tre[MAXN];
void build_nod(int &x, int l, int r, bool unwork){
x=++tot;
if(unwork) tre[x].val=r-l+1,tre[x].lazy=1;
else tre[x].val=0,tre[x].lazy=-1;
}
void push_down(int x, int xl, int xr){
if(tre[x].lazy==0) return;
if(tre[x].lazy==1){
if(tre[x].sl==0) build_nod(tre[x].sl, xl, mid, 1);
else tre[tre[x].sl].val=(mid)-(xl)+1,tre[tre[x].sl].lazy=1;
if(tre[x].sr==0) build_nod(tre[x].sr, mid+1, xr, 1);
else tre[tre[x].sr].val=(xr)-(mid+1)+1,tre[tre[x].sr].lazy=1;
}else{
if(tre[x].sl==0) build_nod(tre[x].sl, xl, mid, 0);
else tre[tre[x].sl].val=0,tre[tre[x].sl].lazy=-1;
if(tre[x].sr==0) build_nod(tre[x].sr, mid+1, xr, 0);
else tre[tre[x].sr].val=0,tre[tre[x].sr].lazy=-1;
}
tre[x].lazy=0;
}
void change(int &x, int xl, int xr, int l, int r, bool unwork){
if(x==0){
build_nod(x, l, r, unwork);
return;
}
if(l<=xl&&xr<=r){
if(unwork) tre[x].val=xr-xl+1,tre[x].lazy=1;
else tre[x].val=0,tre[x].lazy=-1;
return;
}
push_down(x, xl, xr);
if(l<=mid) change(tre[x].sl, xl, mid,l, r, unwork);
if(mid<r) change(tre[x].sr, mid+1, xr, l, r, unwork);
tre[x].val=tre[tre[x].sl].val+tre[tre[x].sr].val;
}
int main()
{
scanf("%d %d", &n, &q);
int root=0;
change(root, 1, n, 1, n, 0);
while(q--){
int l,r,k;
scanf("%d %d %d", &l, &r, &k);
if(k==1) change(root, 1, n, l, r, 1);
else change(root, 1, n, l, r, 0);
printf("%d\n", n-tre[root].val);
}
return 0;
}
CF915E 动态开线段树的更多相关文章
- Find the median(2019年牛客多校第七场E题+左闭右开线段树)
题目链接 传送门 题意 每次往集合里面添加一段连续区间的数,然后询问当前集合内的中位数. 思路 思路很好想,但是卡内存. 当时写的动态开点线段树没卡过去,赛后机房大佬用动态开点过了,\(tql\). ...
- ligerui_ligerTree_005_动态增加“树”节点
动态添加ligerTree节点:效果图: 源码地址:http://download.csdn.net/detail/poiuy1991719/8571255 <%@ page language= ...
- LuoguP2617 Dynamic Rankings (动态主席树学习理解)
题目地址 题目链接 题解 动态主席树的板子题.动态主席树其实和静态的有很大差别,虽然同样是n个根,但是节点并不能共用,每个根节点表示bit上的一段区间. 所以其实是个树套树的东西来着,外层是bit,内 ...
- HDU1199 动态线段树 // 离散化
附动态线段树AC代码 http://acm.hdu.edu.cn/showproblem.php?pid=1199 因为昨天做了一道动态线段树的缘故,今天遇到了这题没有限制范围的题就自然而然想到了动态 ...
- HDU5367 思维map // 动态线段树
地主毛毛有n座山,这些山在地主家门前排成一条直线.这些山一开始均有相同的高度. 每一天,毛毛都会要求花花开挖机把几座山挖掉一定高度,或者给一些山堆上一些高度.并且要求花花报告现在有多少座山属于“高山 ...
- 2019 ICPC上海网络赛 A 题 Lightning Routing I (动态维护树的直径)
题目: 给定一棵树, 带边权. 现在有2种操作: 1.修改第i条边的权值. 2.询问u到其他一个任意点的最大距离是多少. 题解: 树的直径可以通过两次 dfs() 的方法求得.换句话说,到任意点最远的 ...
- 【2019.7.25 NOIP模拟赛 T3】树(tree)(dfs序列上开线段树)
没有换根操作 考虑如果没有换根操作,我们该怎么做. 我们可以求出原树的\(dfs\)序列,然后开线段树维护. 对于修改操作,我们可以倍增求\(LCA\),然后在线段树上修改子树内的值. 对于询问操作, ...
- 在Asp.net core使用配置Json创建动态目录树
一.前言 使用动态目录树可以使左边栏中的目录更加灵活,本文介绍如何将目录保存在json配置文件中,再读取出来经过处理后生成目录树. 二.数据结构 1. TreeMenuNode类名 将TreeMenu ...
- 左闭右开线段树 2019牛客多校(第七场)E_Find the median(点代表区间
目录 题意 一种解析 AC_Code @(2019第七场牛客 E_Find the median 左闭右开线段树) 题意 链接:here 我理解的题意就是:初始序列为空,有\(n(400000)\)次 ...
随机推荐
- 解析spring启动加载dubbo过程
一:简单配置 web.xml <context-param> <param-name>contextConfigLocation</param-name> < ...
- 字符串模式匹配算法——BM、Horspool、Sunday、KMP、KR、AC算法
ref : https://dsqiu.iteye.com/blog/1700312 本文内容框架: §1 Boyer-Moore算法 §2 Horspool算法 §3 Sunday算法 §4 KMP ...
- AES密码算法详解(转自https://www.cnblogs.com/luop/p/4334160.html)
0 AES简介 我们知道数据加密标准(Data Encryption Standard: DES)的密钥长度是56比特,因此算法的理论安全强度是256.但二十世纪中后期正是计算机飞速发展的阶段,元器件 ...
- 12.java中参数传递机制---形参和实参
1.形参:用来接收调用该方法时传递的参数.只有在被调用的时候才分配内存空间,一旦调用结束,就释放内存空间.因此仅仅在方法内有效. public void swap(int a, int b) { in ...
- IOS 主队列,全局队列的关系
同步,异步,串行,并发 同步和异步代表会不会开辟新的线程.串行和并发代表任务执行的方式. 同步串行和同步并发,任务执行的方式是一样的.没有区别,因为没有开辟新的线程,所有的任务都是在一条线程里面执行. ...
- 详解为什么设置overflow为hidden可以清除浮动带来的影响
1.问题起源 在平时的业务开发写CSS中,为了满足页面布局,元素的浮动特性我们用的不能再多了.使用浮动的确能够解决一些布局问题,但是也带了一些副作用影响,比如,父元素高度塌陷,我们有好几种可以清除浮动 ...
- 串口工具kermit(ubuntu)
安装 # sudo apt-get install ckermit 配置 kermit启动时,会首先查找~/.kermrc,然后再遍历/etc/kermit/kermrc # vi /etc/kerm ...
- kNN(K-Nearest Neighbor)最邻近规则分类(转)
KNN最邻近规则,主要应用领域是对未知事物的识别,即判断未知事物属于哪一类,判断思想是,基于欧几里得定理,判断未知事物的特征和哪一类已知事物的的特征最接近: K最近邻(k-Nearest Neighb ...
- CentOS 7 配置VNCServer
因为一直在用xmanager ,所以CentOS 7 上没过VNCSserver了,最近安装Oracle19C ,xmanager 总是卡死,所以配置VNC. 发现仅仅yum install -y t ...
- 【2017-12-06】winfrom 窗体自启最大化,控件自适应
先将窗体windowstate属性设置为Maximized public partial class Form1 : Form { public Form1() { InitializeCompone ...