可以把翻倍的操作看作是一个查询和修改(增加刚查询得来的值)的符合操作,然后做cdq就行了

 #include<bits/stdc++.h>
#define pa pair<int,int>
#define lowb(x) ((x)&(-(x)))
#define REP(i,n0,n) for(i=n0;i<=n;i++)
#define PER(i,n0,n) for(i=n;i>=n0;i--)
#define MAX(a,b) ((a>b)?a:b)
#define MIN(a,b) ((a<b)?a:b)
#define CLR(a,x) memset(a,x,sizeof(a))
#define rei register int
using namespace std;
typedef long long ll;
const int maxn=; inline ll rd(){
ll x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} struct Node{
int x,y,tp,id;
}op[maxn];
int N,M,rg[maxn],tmp[maxn];
ll tr[maxn],ans[maxn]; inline void add(int x,ll y){
for(;x<=M;x+=lowb(x)) tr[x]+=y;
}
inline ll query(int x){
ll re=;for(;x;x-=lowb(x)) re+=tr[x];return re;
} inline bool cmp(int a,int b){
return op[a].x<op[b].x;
} void cdq(int l,int r){
if(l>=r) return;
// printf("!%d %d\n",l,r);
int m=(l+r)>>;
cdq(l,m);
memcpy(tmp+l,rg+l,*(r-l+));
sort(tmp+l,tmp+m+,cmp);sort(tmp+m+,tmp+r+,cmp);
int p=l,q=m+;
for(;q<=r&&op[tmp[q]].x<op[tmp[l]].x;q++);
for(;q<=r;p++){
// printf("%d %d\n",p,q);
Node a=op[tmp[p]];
if(a.tp==)
add(a.y,);
else if(a.tp==)
add(a.y,ans[a.id]);
for(int i=q;i<=r&&op[tmp[i]].x==a.x;i++){
if(op[tmp[i]].y==a.y&&op[tmp[i]].tp==){
// printf("!!%d\n",tmp[i]);
if(a.tp==) ans[op[tmp[i]].id]++;
else if(a.tp==) ans[op[tmp[i]].id]+=ans[a.id];
}
}
for(;q<=r&&(p==m||op[tmp[q]].x<op[tmp[p+]].x);q++){
// printf("%d\n",q);
if(op[tmp[q]].tp==){
ans[op[tmp[q]].id]+=query(op[tmp[q]].y);
}
}
}
p--;
while(p>=l){
Node a=op[tmp[p--]];
if(a.tp==)
add(a.y,-);
else if(a.tp==)
add(a.y,-ans[a.id]);
}
cdq(m+,r);
} int main(){
freopen("21.in","r",stdin);
freopen("21.txt","w",stdout);
rei i;
N=rd();
for(i=;i<=N;i++){
char s[];
scanf("%s",s);
if(s[]=='Q') op[i].tp=;
else if(s[]=='A') op[i].tp=;
else op[i].tp=;
op[i].x=rd(),op[i].y=rd(),op[i].id=i;
M=max(M,op[i].y);
rg[i]=i;
}
cdq(,N);
for(i=;i<=N;i++) if(op[i].tp==) printf("%lld\n",ans[i]);
return ;
}

suoi21 高能显示屏 (cdq分治)的更多相关文章

  1. suoi44 核能显示屏 (cdq分治)

    首先二维树状数组肯定开不下 仿照二维树状数组的做法,如果有差分数组$d[i][j]=a[i][j]-a[i-1][j]-a[i][j-1]+a[i-1][j-1]$,那么就有: $$sum[x][y] ...

  2. 【教程】简易CDQ分治教程&学习笔记

    前言 辣鸡蒟蒻__stdcall终于会CDQ分治啦!       CDQ分治是我们处理各类问题的重要武器.它的优势在于可以顶替复杂的高级数据结构,而且常数比较小:缺点在于必须离线操作. CDQ分治的基 ...

  3. BZOJ 2683 简单题 ——CDQ分治

    [题目分析] 感觉CDQ分治和整体二分有着很本质的区别. 为什么还有许多人把他们放在一起,也许是因为代码很像吧. CDQ分治最重要的是加入了时间对答案的影响,x,y,t三个条件. 排序解决了x ,分治 ...

  4. HDU5618 & CDQ分治

    Description: 三维数点 Solution: 第一道cdq分治...感觉还是很显然的虽然题目不能再傻逼了... Code: /*=============================== ...

  5. 初识CDQ分治

    [BZOJ 1176:单点修改,查询子矩阵和]: 1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 200 ...

  6. HDU5322 Hope(DP + CDQ分治 + NTT)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5322 Description Hope is a good thing, which can ...

  7. BZOJ4170 极光(CDQ分治 或 树套树)

    传送门 BZOJ上的题目没有题面-- [样例输入] 3 5 2 4 3 Query 2 2 Modify 1 3 Query 2 2 Modify 1 2 Query 1 1 [样例输出] 2 3 3 ...

  8. BZOJ2683 简单题(CDQ分治)

    传送门 之前听别人说CDQ分治不难学,今天才知道果真如此.之前一直为自己想不到CDQ的方法二很不爽,今天终于是想出来了一道了,太弱-- cdq分治主要就是把整段区间分成两半,然后用左区间的值去更新右区 ...

  9. BNUOJ 51279[组队活动 Large](cdq分治+FFT)

    传送门 大意:ACM校队一共有n名队员,从1到n标号,现在n名队员要组成若干支队伍,每支队伍至多有m名队员,求一共有多少种不同的组队方案.两个组队方案被视为不同的,当且仅当存在至少一名队员在两种方案中 ...

随机推荐

  1. React + js-xlsx构建Excel文件上传预览功能

    首先要准备react开发环境以及js-xlsx插件 1. 此处省略安装react安装步骤 2.下载js-xlsx插件 yarn add xlsx 或者 npm install xlsx 在项目中引入 ...

  2. .NETCore_生成实体

    先安装以下三个包,或者使用Nuget引用 不要问我为什么,按哥说的做吧: Install-Package Microsoft.EntityFrameworkCore.SqlServer Install ...

  3. Mvc4_ @RenderBody、@RenderPage、@RenderSection用法

    一.@RenderBody 当创建基于_Layout.cshtml布局页面的视图时,视图的内容会和布局页面合并,而新创建视图的内容会通过_Layout.cshtml布局页面的@RenderBody() ...

  4. 2018年高教社杯全国大学生数学建模竞赛B题解题思路

    题目 先贴下B题的题目吧 问题B    智能RGV的动态调度策略 图1是一个智能加工系统的示意图,由8台计算机数控机床(Computer Number Controller,CNC).1辆轨道式自动引 ...

  5. JS 实现计算一段文字中的字节数,字母数,数字数,行数,汉字数。

    看到了匹配,第一个想到了用正则表达式,哈哈,果然很方便.不过正则表达式高深莫测!我还没有研究明白啊..目前学了点皮毛.代码如下: <!DOCTYPE html PUBLIC "-//W ...

  6. 第三周作业————————word count

    #include <stdio.h> void main() { FILE *fp; , str, word, pu, ch; int g; str = ; word = ; pu = ; ...

  7. BUAA软工个人作业Week3-案例分析

    一. 调研评测 评测项目:为了联系移动和PC版,我同时下载了必应词典的Android版本和UWP版本,选择UWP的原因是想看看微软推广的UWP在微软自己的应用上的效果.当然主要是对安卓的测评(UWP用 ...

  8. [转]Spring通过@Value注解注入属性的几种方式

    原文地址:https://blog.csdn.net/csujiangyu/article/details/50945486 ------------------------------------- ...

  9. 转载 loadrunner的一些问题解决

    sckOutOfMemory 7 内存不足  sckInvalidPropertyValue 380 属性值不效  sckGetNotSupported 394 属性不可读  sckGetNotSup ...

  10. php中获取数据 php://input、$_POST与$GLOBALS['HTTP_RAW_POST_DATA']三者的区别

    $_POST 只有Coentent-Type的值为application/x-www.form-urlencoded和multipart/form-data两种类型时,$_POST才能获取到数据. $ ...