Vijos1448校门外的树 题解
Vijos1448校门外的树 题解

以上就是括号序列的过程。简单的说,就是更新区间[a,b]时,点a记录左括号数,点b记录右括号数,查询区间[a,b]时,即为b之前(包括b)的左括号数-a之前的右括号数。
#include "bits/stdc++.h"
#define maxN 50010 using namespace std ;
typedef long long QAQ ; struct Tree
{
int l , r ;
QAQ liml , limr ;//左括号右括号
}; Tree tr[maxN << ]; void Build_Tree ( int x , int y , int i )//建树
{
tr[i].l = x ;
tr[i].r = y ;
if( x == y )return ;
else
{
QAQ mid = (tr[i].l + tr[i].r) >> ;
Build_Tree ( x , mid , i << );
Build_Tree ( mid + , y , i << | );
return ;
}
} void Update_left ( int w , int i )
{
if( w == tr[i].l && w == tr[i].r )tr[i].liml++;//找到目标节点
else
{
QAQ mid = (tr[i].l + tr[i].r) >> ;
if( w > mid )Update_left( w , i << | );//找右儿子
else if( w <= mid)Update_left( w , i << );//找左儿子
tr[i].liml = tr[i << ].liml + tr[i << | ].liml ;//回溯更新
}
} void Update_right ( int w , int i )//同Update_left
{
if( w == tr[i].l && w == tr[i].r )tr[i].limr++;
else
{
QAQ mid = (tr[i].l + tr[i].r) >> ;
if( w > mid )Update_right( w , i << | );
else if( w <= mid)Update_right( w , i << );
tr[i].limr = tr[i << ].limr + tr[i << | ].limr ;
}
} QAQ Query_left ( int q , int w , int i )//同Query_right
{
if( q <= tr[i].l && w >= tr[i].r )return tr[i].liml ;
else
{
QAQ mid = (tr[i].l + tr[i].r) >> ;
if ( q > mid )return Query_left ( q , w , i << | );
else if ( w <= mid ) return Query_left ( q , w , i << );
else return Query_left ( q , w , i << | ) + Query_left ( q , w , i << );
}
} QAQ Query_right ( int q , int w , int i )
{
if( q <= tr[i].l && w >= tr[i].r )return tr[i].limr ;//找到目标区间直接返回
else
{
QAQ mid = (tr[i].l + tr[i].r) >> ;
if ( q > mid )return Query_right ( q , w , i << | );//找右儿子
else if ( w <= mid ) return Query_right ( q , w , i << );//找左儿子
else return Query_right ( q , w , i << | ) + Query_right ( q , w , i << );//左右儿子都查找
}
} int main()
{
int N, M, op, ll, rr ;
scanf("%d %d", &N, &M);
Build_Tree ( , N , ) ;//建树
while(M--)
{
scanf("%d%d%d", &op, &ll, &rr);
if( op == )
{
Update_left ( ll , );//添加左括号
Update_right ( rr , );//添加右括号
}
else
{
QAQ ans = Query_left( , rr , );
if (ll != )ans -= Query_right( , ll - , );//当ll不等于1时再相减,否则栈会炸
printf("%I64d\n", ans);
}
}
return ;
}
Vijos1448校门外的树 题解的更多相关文章
- Vijos1448 校门外的树 [树状数组]
题目传送门 校门外的树 描述 校门外有很多树,有苹果树,香蕉树,有会扔石头的,有可以吃掉补充体力的……如今学校决定在某个时刻在某一段种上一种树,保证任一时刻不会出现两段相同种类的树,现有两个操作:K= ...
- vijos1448校门外的树
描述 校门外有很多树,有苹果树,香蕉树,有会扔石头的,有可以吃掉补充体力的……如今学校决定在某个时刻在某一段种上一种树,保证任一时刻不会出现两段相同种类的树,现有两个操作:K=1,K=1,读入l.r表 ...
- 洛谷P1047校门外的树题解
题目 此题是一个模拟题,但需要注意的一点就是它的树是从数轴的0开始,所以我们也要从0开始,这样才能实现代码. 代码: #include<iostream> using namespace ...
- 洛谷 P1047 校门外的树 题解
Case 1. 本题其实不难,直接模拟就可以了.时间复杂度: \(O(L \times M)\) Case 2. 考虑一个简单的增强:把原来的: \[L \leq 10^4,M \leq 10^2 \ ...
- >题解< 校门外的树
题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是 11 米.我们可以把马路看成一个数轴,马路的一端在数轴 00 的位置,另一端在 LL 的位置:数轴上的每个整数点,即 0,1 ...
- JDOJ 2197: 校门外的树
JDOJ 2197: 校门外的树 题目传送门 Description 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米. 我们可以把马路看成一个数轴,马路的一端在数轴1的位置,另一 ...
- NC16649 [NOIP2005]校门外的树
NC16649 [NOIP2005]校门外的树 题目 题目描述 某校大门外长度为 \(L\) 的马路上有一排树,每两棵相邻的树之间的间隔都是 \(1\) 米.我们可以把马路看成一个数轴,马路的一端在数 ...
- P1047 校门外的树
P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...
- OpenJudge计算概论-校门外的树
/*======================================================================== 校门外的树 总时间限制: 1000ms 内存限制: ...
随机推荐
- sdut 487-3279【哈希查找,sscanf ,map】
487-3279 Time Limit: 2000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 题目链接: sdut: http://acm.sdut.ed ...
- python列表分组的技巧
今天项目上需要到的. 如,将并行部署的机器分批次. 一次十台机器,如果分3次并行部署,则第一次123,第二次456,第三次789,第四次10. #coding=utf-8 a=[1,2,3,4,5,6 ...
- [Win32命令行] 更改提示符字符串(PS1)
当进入的目录比较深时, cmd的提示符几乎会占据整行, 很烦, 于是Google之... 参考: A better PROMPT for CMD.EXE ... 更改方式: 1. pro ...
- 初识SQL Server Integration Service
SSIS(SQL Server Integration Service)是Microsoft 从SQL Server2005 以后发布的,现在一直跟随每个SQL server版本.它是Microsof ...
- VMWARE虚拟机CentOS6.4系统使用主机无线网卡上网的三种方法介绍
转自:http://www.jb51.net/network/98820.html 如何真正的实现VMWARE虚拟机CentOS6.4系统使用主机无线网卡上网 环境:WIN7旗舰版,台式机,U盘无 ...
- CSS实现打字效果
.print{ width:250px; white-space:nowrap; overflow:hidden; -webkit-animation: dy 3s steps(60, end) in ...
- Spark Streaming容错的改进和零数据丢失
本文来自Spark Streaming项目带头人 Tathagata Das的博客文章,他现在就职于Databricks公司.过去曾在UC Berkeley的AMPLab实验室进行大数据和Spark ...
- JMeter正则表达式-学习(3)
同时关联多个值的方法: { : ", : "results": : [ : : { : : : "total_earnings":"&quo ...
- express-4 质量保证(1)
QA 在Web开发中,质量可以分解为四个维度: 到达率: 到达率是指产品的市场普及程度,即查看网站或使用服务的人数.到达率和盈利能力是正相关关系:访问网站的人越多,购买产品或服务的人就越多.从开发的角 ...
- Editthiscookie
Editthiscookie,联调,.s环境加cookie才能访问.laravel