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)\)次 ...
随机推荐
- SVN操作出现locked错误解决办法
SVN操作出现locked错误解决办法:在SVN中执行 commit 操作时,在更新过程中,中断过,或者因为其他原因导致SVN 出现 locked 异常. 解决办法:1. 选中出现异常的文件,右键 - ...
- ORA-16401: archivelog rejected by RFS
ORA-16401: archivelog rejected by RFS 无线出单系统邮件告警10.111.20.1 1. 报错 SYS > ! oerr ora 16041 1604 ...
- (二十二)SpringBoot之使用mybatis generator自动生成bean、mapper、mapper xml
一.下载mybatis generator插件 二.生成generatorConfig.xml new一个generatorConfig.xml 三.修改generatorConfig.xml 里面的 ...
- 路由器开源系统openwrt配置页面定制
1. 新建虚拟机,百度文库有一篇<使用VMware安装OpenWrt>,地址:http://wenku.baidu.com/link?url=NkvaQpTf2dR8FpYn7JD9A7- ...
- TCP/IP及http协议 SOAP REST
TCP/IP及http协议: TCP/IP协议主要解决数据如何在网络中传输, 而HTTP是应用层协议,主要解决如何包装数据 SOAP:简单对象访问协议(Simple Object Access Pro ...
- kong 命令(五)plugin
介绍 plugin 插件 是运用在kong网关各模块的功能.在http请求或响应过程中执行的插件: 可以实现认证.负载.加密等功能. kong官网提供了一些插件:https://docs.konghq ...
- 编程模型&编程思想
编程模型 1.面向对象编程OOP 2.面向切面编程AOP Java静态接口,Java动态代理,字节码提升. 面向切面的两个方面: 拦截判断:方法,注解,参数,异常 拦截执行:前置,后置,返回,异常 3 ...
- springboot启动流程(十一)aop切面处理过程
所有文章 https://www.cnblogs.com/lay2017/p/11478237.html 正文 spring的两大核心就是ioc和aop.在关于ioc依赖注入的文章中,我们了解了如何根 ...
- css图片上加文字
第一种方法: 添加一个DIV,采用绝对定位,图片所属DIV为基准 <div style="position:relative;width:100px;height:100px;&quo ...
- DNS zone file
zone file格式最初由Berkeley Internet Name Domain(BIND)软件包使用,但已被其他DNS server software广泛采用.它们中的一些(例如NSD,Pow ...