洛谷P5111 zhtobu3232的线段树
题意:给定线段树,上面若干个节点坏了,求能表示出多少区间。
区间能被表示出当且仅当拆出来的log个节点都是好的。
解:每个区间在最浅的节点处计算答案。
对于每个节点维护从左边过来能有多少区间,从右边过来能有多少区间即可。
说起来水的一批为什么会被评成黑题啊。
#include <bits/stdc++.h> typedef long long LL;
const int N = ;
const LL MO = ; LL lc[N], rc[N], ans;
int tot, ls[N], rs[N];
bool vis[N]; void add(LL L, LL R, LL l, LL r, int &o) {
//printf("%lld %lld %lld %lld %d \n", L, R, l, r, o);
if(!o) o = ++tot;
if(L <= l && r <= R) {
vis[o] = ;
return;
}
LL mid = (l + r) >> ;
if((r - l + ) & ) mid--;
if(L <= mid) add(L, R, l, mid, ls[o]);
if(mid < R) add(L, R, mid + , r, rs[o]);
} void cal(LL l, LL r, int &o) {
if(!o) {
o = ++tot;
LL len = (r - l + ) % MO;
ans = (ans + len * (len + ) / ) % MO;
//printf("[%lld %lld] ans += %lld = %lld \n", l, r, len * (len + 1) / 2, ans);
lc[o] = rc[o] = (len - + MO) % MO;
return;
}
if(l == r) {
ans += (!vis[o]);
//if(!vis[o]) printf("[%lld %lld] ans++ = %lld \n", l, r, ans);
return;
}
LL mid = (l + r) >> ;
if((r - l + ) & ) mid--;
cal(l, mid, ls[o]);
cal(mid + , r, rs[o]);
/// cal
ans = (ans + lc[rs[o]] * rc[ls[o]] % MO) % MO;
//printf("[%lld %lld] ans += %lld * %lld = %lld \n", l, r, lc[rs[o]], rc[ls[o]], ans);
if(!vis[ls[o]]) {
ans = (ans + lc[rs[o]]) % MO;
//printf("[%lld %lld] ans += %lld = %lld \n", l, r, lc[rs[o]], ans);
}
if(!vis[rs[o]]) {
ans = (ans + rc[ls[o]]) % MO;
//printf("[%lld %lld] ans += %lld = %lld \n", l, r, rc[ls[o]], ans);
}
if(!vis[o]) ans++;
lc[o] = lc[ls[o]];
if(!vis[ls[o]]) {
lc[o] = (lc[o] + lc[rs[o]] + ) % MO;
}
rc[o] = rc[rs[o]];
if(!vis[rs[o]]) {
rc[o] = (rc[o] + rc[ls[o]] + ) % MO;
}
//printf("l = %lld r = %lld lc = %lld rc = %lld \n", l, r, lc[o], rc[o]);
return;
} int main() { //printf("%d", sizeof(lc) * 3 / 1048576); LL n; int m, root = ;
scanf("%lld%d", &n, &m);
for(int i = ; i <= m; i++) {
LL l, r;
scanf("%lld%lld", &l, &r);
add(l, r, 1ll, n, root);
}
cal(, n, root);
printf("%lld\n", ans);
return ;
}
AC代码
洛谷P5111 zhtobu3232的线段树的更多相关文章
- P5111 zhtobu3232的线段树
P5111 zhtobu3232的线段树 维护左子树右子树的贡献和跨区间贡献 #include<bits/stdc++.h> using namespace std; typedef lo ...
- 【BZOJ】1012: [JSOI2008]最大数maxnumber /【洛谷】1198(线段树)
Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. 插 ...
- 洛谷题解P4314CPU监控--线段树
题目链接 https://www.luogu.org/problemnew/show/P4314 https://www.lydsy.com/JudgeOnline/problem.php?id=30 ...
- 洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)
洛谷P3372 //线段树 询问区间和,支持区间修改 #include <cstdio> using namespace std; struct treetype { int l,r; l ...
- 洛谷P4065 [JXOI2017]颜色(线段树)
题意 题目链接 Sol 线段树板子题都做不出来,真是越来越菜了.. 根据题目描述,一个合法区间等价于在区间内的颜色没有在区间外出现过. 所以我们可以对于每个右端点,统计最长的左端点在哪里,刚开始以为这 ...
- 洛谷P3960 列队 NOIp2017 线段树/树状数组/splay
正解:动态开点线段树 解题报告: 传送门! 因为最近学主席树的时候顺便get到了动态开点线段树?刚好想起来很久很久以前就想做结果一直麻油做的这题,,,所以就做下好了QAQ 然后说下,这题有很多种方法, ...
- 题解——洛谷P2781 传教(线段树)
可以说是数据结构学傻了的典型案例了 昨天跳到这题上 然后思考了一下 噫!好!线段树裸题 然后打完板子,发现\( n \le 10^9 \) 显然线段树直接做不太行 然后这题又只有普及的难度 然后我就 ...
- 洛谷P4198 楼房重建(线段树)
题意 题目链接 Sol 别问我为什么发两遍 就是为了骗访问量 这个题的线段树做法,,妙的很 首先一个显然的结论:位置\(i\)能被看到当且仅当\(\frac{H_k}{k} < \frac{H_ ...
- 2018.08.16 洛谷P1471 方差(线段树)
传送门 线段树基本操作. 把那个方差的式子拆开可以发现只用维护一个区间平方和和区间和就可以完成所有操作. 同样区间修改也可以简单的操作. 代码: #include<bits/stdc++.h&g ...
随机推荐
- spring初始化bean时执行某些方法完成特定的初始化操作
在项目中经常会在容器启动时,完成特定的初始化操作,如资源文件的加载等. 一 实现的方式有三种: 1.使用@PostConstruct注解,该注解作用于void方法上 2.在配置文件中配置init-me ...
- 建议1---理解Pythonic的概念
对于Pythonic的概念,众人都有自己的看法,但大家心中都认同一个更具体的指南,即Tim Peters的<The Zen of Python>.在这一篇充满禅意的诗篇中,有几点非常深入人 ...
- Hbase的作用
实时动态增加列 多版本的意思为多个用户地址,多个用户信息,多个用户号码
- java静态工厂
本文摘自:https://www.jianshu.com/p/ceb5ec8f1174 本文略长,所以先来个内容提要 序:什么是静态工厂方法 Effective Java 2.1 静态工厂方法与构造器 ...
- 为AI提供数据:构建2017数据创新的总结
本周在微软年度大会上,我们正在讨论组织如何依靠开发人员创造突破性的经验.随着大数据,云和人工智能的融合,创新与破坏正在加速,从未见过.数据是这一融合核心的关键战略资产.当结合云的无限计算能力和机器学习 ...
- Ajax 调用的WCF
支持ajax 跨域调用的WCF搭建 1.新建一个"ASP.NET空Web应用程序"项目. 2.新建一个“WCF服务(支持ajax)”. 3.修改WCFAjaxService.svc ...
- RBS SharePoint 2010 Server.wmv
视频地址: https://www.youtube.com/watch?v=DXi2er514iA&feature=youtu.be
- openwrt-scripts/config/mconf: Syntax error: “(” unexpected错误解决
scripts/config/mconf: Syntax error: “(” unexpected错误解决 从其他地方复制而来的openwrt SDK,放在本地执行make menuconfig时出 ...
- GitHub大佬:供计算机学习鉴黄功能的图片数据库
ps:学无止境 想要构建一套鉴黄系统,必须有大量的真实图片供计算机进行学习,以便于区分开正常图片和黄色图片. 近期有位加拿大程序员在Github上传了图片列表,里面包含了大量图片地址可以供计算机进行学 ...
- Luogu5245 【模板】多项式快速幂(多项式exp)
A(x)k=eklnA(x).泰勒展开之后容易发现k并非在指数上,所以对p取模. #include<iostream> #include<cstdio> #include< ...