才发现扫描线可以用树状数组搞... 致远星患者

(另外根据这篇博文的内容怎么越来越感觉自己往 PJ 入门靠拢了...)

还有一点,咱把树状数组当做线段树来康的话其实一切都会很清晰,这个来张四合一的图:

第一张就是随处可见的 sb 树状数组剖析图了

第二张咱把点补齐了一下,即每个点下面所有层都赋值一份点,然后以第一张图类似的规则连边,同时某个点正下方的点也要向其连边

第三张咱把点长补全了,看起来... 是不是很像线段树了呢? 2333

然后第四张图写了一下某个点 update 时的虚拟状况,某个点一直往上跑就好辣,至于 query 时,类比线段树查询 1~x 内的信息(也就是前缀信息嘛),把查询点对应到这里,不就变成了每次去掉一个 lowbit 嘛

这样,对于受众较少的 OI 龄较大但对于树状数组只是几个模板的(指自己) OIer 们来说,这篇博文的价值大部分就已经完成了...

那么还有一小部分就是树状数组(在理解了以上内容之后),在扫描线中的应用 ...

你可能已经在挠头了??? 线段树不是区间查询搞的扫描线?? 什么时候树状数组也能来凑热闹了?

脑补一下,拆成两个前缀和可不就是区间嘛, 但其实,树状数组不能艹扫描线 【雾 (就算能咱也不会啊 QwQ)

不过在这里,还有一个另一种情况的(伪)扫描线可以用树状数组优化二维前缀和来做

eg

询问 单个矩阵 与 多个矩形(互不相交,划重点) 的面积交之和 , 多组询问 ,资瓷离线 ,要求复杂度一只 log ,并且略略卡常(虽说原题时限给了 10 S 就是了)

数据比较友好,不需要离散... (讲道理可能 PJ 的同学倒能一眼看出二维前缀和,然后想着用 BIT 优化??? 虽说还是很超纲就是了)

Code

真 tm 好打,明明用线段树维护的话会是个码农题的说,用了树状数组多在纸上比划两下就好了

//by Judge
#include<bits/stdc++.h>
#define ll long long
#define Rg register
#define pb push_back
#define P pair<int,int>
#define fi first
#define se second
#define fp(i,a,b) for(Rg int i(a),I=(b)+1;i<I;++i)
#define fd(i,a,b) for(Rg int i(a),I=(b)-1;i>I;--i)
#define go(u) for(Rg int i=head[u],v=e[i].to;i;v=e[i=e[i].nxt].to)
#define open(S) freopen(S".in","r",stdin),freopen(S".out","w",stdout)
using namespace std;
const int M=2e6+3;
typedef ll arr[M];
#define getchar() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++)
char buf[1<<21],*p1=buf,*p2=buf;
inline int read(){ int x=0,f=1; char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
for(;isdigit(c);c=getchar()) x=x*10+c-'0'; return x*f;
} char sr[1<<21],z[20];int CCF=-1,Z;
inline void Ot(){fwrite(sr,1,CCF+1,stdout),CCF=-1;}
inline void print(ll x,char chr='\n'){
if(CCF>1<<20)Ot();if(x<0)sr[++CCF]=45,x=-x;
while(z[++Z]=x%10+48,x/=10);
while(sr[++CCF]=z[Z],--Z);sr[++CCF]=chr;
} int n,m,W,L; ll ans[M]; vector<P> ql[M],qr[M],op[M];
namespace BIT {
arr f,fx,fy,fs;
#define lowbit(x) (x&-x)
inline void add(int x,int l,int r,ll s,int v) { ++x;
while(x<=L+1) f[x]+=v,fx[x]+=v*l,fy[x]+=v*r,fs[x]+=v*s,x+=lowbit(x);
}
inline ll ask(int x,int l,int r) { ll sx=0,sy=0,s=0,ct=0; ++x;
while(x) ct+=f[x],sx+=fx[x],sy+=fy[x],s+=fs[x],x^=lowbit(x);
return ct*l*r-l*sy-r*sx+s;
}
} using namespace BIT;
signed main() { open("intersec"); int a,b,c,d;
n=read(),m=read(),W=read(),L=read();
fp(i,1,n) a=read(),b=read(),c=read(),d=read(),
op[a].pb(P(b,1)),op[a].pb(P(d,-1)),op[c].pb(P(b,-1)),op[c].pb(P(d,1));
fp(i,1,m) a=read(),b=read(),c=read(),d=read(),
ql[a].pb(P(d,i)),qr[a].pb(P(b,i)),ql[c].pb(P(b,i)),qr[c].pb(P(d,i)); fp(i,0,W) {
for(auto x: qr[i]) ans[x.se]+=ask(x.fi,i,x.fi);
for(auto x: ql[i]) ans[x.se]-=ask(x.fi,i,x.fi);
for(auto x: op[i]) add(x.fi,i,x.fi,1ll*i*x.fi,x.se);
} fp(i,1,m) print(ans[i],"\n "[i<m]); return Ot(),0;
}

inline void 树状数组神奇感悟【雾的更多相关文章

  1. HDU 5869.Different GCD Subarray Query-区间gcd+树状数组 (神奇的标记右移操作) (2016年ICPC大连网络赛)

    树状数组... Different GCD Subarray Query Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/6 ...

  2. 【BZOJ-3790】神奇项链 Manacher + 树状数组(奇葩) + DP

    3790: 神奇项链 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 304  Solved: 150[Submit][Status][Discuss] ...

  3. [清华集训2017]小 Y 和地铁(神奇思路,搜索,剪枝,树状数组)

    世界上最不缺的就是好题. 首先考虑暴搜.(还有什么题是从这东西推到正解的……) 首先单独一个换乘站明显没用,只用考虑一对对的换乘站. 那么有八种情况:(从题解偷图)         然后大力枚举每个换 ...

  4. BZOJ 3790 神奇项链(manacher+DP+树状数组)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3790 [题目大意] 问最少用几个回文串可以构成给出串,重叠部分可以合并 [题解] 我们 ...

  5. BZOJ 2434: [Noi2011]阿狸的打字机 [AC自动机 Fail树 树状数组 DFS序]

    2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 2545  Solved: 1419[Submit][Sta ...

  6. 【BZOJ】1901: Zju2112 Dynamic Rankings(区间第k小+树状数组套主席树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1901 首先还是吐槽时间,我在zoj交无限tle啊!!!!!!!!我一直以为是程序错了啊啊啊啊啊啊. ...

  7. 【BZOJ】1146: [CTSC2008]网络管理Network(树链剖分+线段树套平衡树+二分 / dfs序+树状数组+主席树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1146 第一种做法(时间太感人): 第二种做法(rank5,好开心) ================ ...

  8. HDU5126---stars (CDQ套CDQ套 树状数组)

    题意:Q次操作,三维空间内 每个星星对应一个坐标,查询以(x1,y1,z1) (x2,y2,z2)为左下顶点 .右上顶点的立方体内的星星的个数. 注意Q的范围为50000,显然离散化之后用三维BIT会 ...

  9. [luogu P3801] 红色的幻想乡 [线段树][树状数组]

    题目背景 蕾米莉亚的红雾异变失败后,很不甘心. 题目描述 经过上次失败后,蕾米莉亚决定再次发动红雾异变,但为了防止被灵梦退治,她决定将红雾以奇怪的阵势释放. 我们将幻想乡看做是一个n*m的方格地区,一 ...

随机推荐

  1. CodeForces–471D--MUH and Cube Walls(KMP)

    Time limit         2000 ms  Memory limit  262144 kB Polar bears Menshykov and Uslada from the zoo of ...

  2. xpath元素定位方法

    XPath 使用路径表达式来选取 XML 文档中的节点或者节点集.这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似.XPath 含有超过 100 个内建的函数.这些函数用于字符串值.数值 ...

  3. Java连接MQTT服务-tcp方式

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  4. tensorflow实现LeNet-5模型

    网络结构如下: INPUT: [28x28x1] weights: 0 CONV5-32: [28x28x32] weights: (5*5*1+1)*32 POOL2: [14x14x32] wei ...

  5. shell初级-----结构化命令

    if-then语句 bash shell的if语句会执行if后面的那个命令,如果该命令的退出码状态为0会执行then部分的命令,如果是其他值不会执行. 格式如下: if command then co ...

  6. 【6】font-size 字体属性

    font-style                         --  字体风格 font-variant                      -- 小型大写字母文本 font-weigh ...

  7. matplotlib之折线图

    1.案例一 # coding=utf-8 from matplotlib import pyplot as plt import random # 设置字体相关 from matplotlib imp ...

  8. Python线程和协程

    写在前面 好好学习 天天向上 一.线程 1.关于线程的补充 线程:就是一条流水线的执行过程,一条流水线必须属于一个车间: 那这个车间的运行过程就是一个进程: 即一个进程内,至少有一个线程: 进程是一个 ...

  9. jquery 教程网

  10. 求第n个质数

    输入一个不超过 10000 的正整数 n,求第n个质数 样例输入 10 样例输出 29 题目地址 #include<stdio.h> #include<math.h> int ...