BZOJ 3262 陌上花开 (三维偏序CDQ+树状数组)
题目大意:
三维偏序裸题
首先,把三元组关于$a_{i}$排序
然后开始$CDQ$分治,回溯后按$b_{i}$排序
现在要处理左侧对右侧的影响了,显然现在左侧三元组的$a_{i}$都小于等于右侧
而$c_{i}$这一维需要用权值树状数组维护
归并排序时,已知左侧右侧两个指针分别是$i,j$
如果$b_{i} \leq bj$,将左侧已经遍历过的三元组的$c_{i}$推入树状数组,然后$i++$
如果$b_{i}>bj$,那么右侧能取到的贡献就是树状数组内$\leq c_{j}$的三元组数量,然后$j++$
可三元组有重复的啊!
如果我们不去重,假设有两个相同的三元组,靠前的三元组会得不到后面的贡献
还需要去重,并额外记录相同三元组数量
这道题的判定条件三个元是小于等于
发现我们只关于$a_{i}$排序也不行啊
在归并过程中会发现有一些$b_{i}$或者是$c_{i}$明明比较大,却得不到后面较小的贡献
这是由于小于等于的情况也合法,而我们必须让较大的在后面,才能保证后面能取到前面的贡献
所以排序过程中第二维还要按$b_{i}$排序,第三维按$c_{i}$
#include <vector>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N1 100100
#define ll long long
#define dd double
#define inf 0x3f3f3f3f3f3f3f3fll
using namespace std; int gint()
{
int ret=,fh=;char c=getchar();
while(c<''||c>''){if(c=='-')fh=-;c=getchar();}
while(c>=''&&c<=''){ret=ret*+c-'';c=getchar();}
return ret*fh;
}
int n,nn,K;
struct node{
int id,num,a,b,c;
friend bool operator == (const node &s1,const node &s2)
{return (s1.a==s2.a)&&(s1.b==s2.b)&&(s1.c==s2.c);}
friend bool operator < (const node &s1,const node &s2)
{
if(s1.a!=s2.a) return s1.a<s2.a;
if(s1.b!=s2.b) return s1.b<s2.b;
return s1.c<s2.c;
}
}p[N1],t[N1],tmp[N1]; struct b_{i}T{
int s[N1<<];
void update(int x,int w){for(int i=x;i<=K;i+=(i&(-i))) s[i]+=w;}
int query(int x){int ans=; for(int i=x;i>;i-=(i&(-i))) ans+=s[i]; return ans;}
}b;
int f[N1],hs[N1],que[N1],tl;
void CDQ(int L,int R)
{
if(R-L<=) return;
int M=(L+R)>>;
CDQ(L,M); CDQ(M,R);
int i=L,j=M,cnt=;
while(i<M&&j<R)
{
if(t[i].b<=t[j].b){
b.update(t[i].c,t[i].num);
tmp[++cnt]=t[i]; i++; que[++tl]=cnt;
}else{
f[t[j].id]+=b.query(t[j].c);
tmp[++cnt]=t[j]; j++;
}
}
while(i<M){tmp[++cnt]=t[i]; i++;}
while(j<R){f[t[j].id]+=b.query(t[j].c); tmp[++cnt]=t[j]; j++;}
while(tl) i=que[tl--],b.update(tmp[i].c,-tmp[i].num);
for(i=L;i<R;i++) t[i]=tmp[i-L+];
} int main()
{
scanf("%d%d",&n,&K);
int i;
for(i=;i<=n;i++) p[i].a=gint(),p[i].b=gint(),p[i].c=gint();
sort(p+,p+n+);
for(i=;i<=n;i++)
if(!(p[i]==p[i-])) t[++nn]=p[i],t[nn].num=;
else t[nn].num++;
for(i=;i<=nn;i++) t[i].id=i;
CDQ(,nn+);
for(i=;i<=nn;i++) hs[f[t[i].id]+t[i].num-]+=t[i].num;
for(i=;i<n;i++) printf("%d\n",hs[i]);
return ;
}
BZOJ 3262 陌上花开 (三维偏序CDQ+树状数组)的更多相关文章
- BZOJ 2141 排队 (三维偏序CDQ+树状数组)
题目大意:略 洛谷传送门 和 [CQOI2015]动态逆序对 这道题一样的思路 一开始的序列视为$n$次插入操作 把每次交换操作看成四次操作,删除$x$,删除$y$,加入$x$,加入$y$ 把每次操作 ...
- Luogu 3810 & BZOJ 3262 陌上花开/三维偏序 | CDQ分治
Luogu 3810 & BZOJ 3263 陌上花开/三维偏序 | CDQ分治 题面 \(n\)个元素,每个元素有三个值:\(a_i\), \(b_i\) 和 \(c_i\).定义一个元素的 ...
- BZOJ 2716/2648 SJY摆棋子 (三维偏序CDQ+树状数组)
题目大意: 洛谷传送门 这明明是一道KD-Tree,CDQ分治是TLE的做法 化简式子,$|x1-x2|-|y1-y2|=(x1+y1)-(x2+y2)$ 而$CDQ$分治只能解决$x1 \leq x ...
- BZOJ 1176/2683 Mokia (三维偏序CDQ+树状数组)
题目大意: 洛谷传送门 三维偏序裸题.. 每次操作都看成一个三元组$<x,y,t>$,表示$x,y$坐标和操作时间$t $ 询问操作拆成$4$个容斥 接下来就是$CDQ$了,外层按t排序, ...
- BZOJ 3295 [CQOI2011]动态逆序对 (三维偏序CDQ+树状数组)
题目大意: 题面传送门 还是一道三维偏序题 每次操作都可以看成这样一个三元组 $<x,w,t>$ ,操作的位置,权值,修改时间 一开始的序列看成n次插入操作 我们先求出不删除时的逆序对总数 ...
- bzoj3262陌上花开 三维数点 cdq+树状数组
大早上的做了一道三维数点一道五位数点,神清气爽! 先给一维排序,变成一个奇怪的动态的二维数点(相当于有一个扫描面扫过去,导致一系列的加点和询问) 然后cdq分治,再变回静态,考虑前半段对后半段的影响 ...
- 洛谷P3810-陌上开花(三维偏序, CDQ, 树状数组)
链接: https://www.luogu.org/problem/P3810#submit 题意: 一个元素三个属性, x, y, z, 给定求f(b) = {ax <= bx, ay < ...
- bzoj3295 [Cqoi2011]动态逆序对 cdq+树状数组
[bzoj3295][Cqoi2011]动态逆序对 2014年6月17日4,7954 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数. ...
- bzoj3262: 陌上花开(CDQ+树状数组处理三维偏序问题)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3262 题目大意:中文题目 具体思路:CDQ可以处理的问题,一共有三维空间,对于第一维我们 ...
随机推荐
- input标签处理多文件上传
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name ...
- php 常用header
//定义编码 header( 'Content-Type:text/html;charset=utf-8 '); //Atom header('Content-type: application/at ...
- Python包结构和函数式编程
# 包的结构 |--包 |--|-- __init__.py 包的标志文件 |--|-- 模块1 |--|-- 模块2 |--|-- 子包(子文件夹) |--|--|-- __init__.py 包的 ...
- 服务器重启后启动Docker命令
启动步骤: 1.启动Docker 守护进程 systemctl daemon-reload 2.Docker启动命令: systemctl start docker 3.查看docker服务是否启动 ...
- C#-WinForm中文本框的中文乱码问题
上面这句话可以解决textbox中的中文乱码问题 来自为知笔记(Wiz) 附件列表 QQ图片20151218124007.png
- 给 string 添加一个 GetInputStream 扩展方法
有时候,我们须要读取一些数据,而无论这数据来源于磁盘上的数据文件,还是来源于网络上的数据.于是.就有了以下的 StringExtensions.cs: using System; using Syst ...
- 【云快讯】之四十八《IBM和Cisco最新收购,加强Openstack易用能力》
2015-06-08 张晓东 东方云洞察 点击上面的链接文字,能够高速关注"东方云洞察"公众号 本周宣布的两起收购引人注意.思科购买Piston云计算公司.同期IBM的收购Blue ...
- iframe显示滚动栏
子页面通过iframe载入.出现了竖向滚动栏 最后查出原因:文档申明 iframe有滚动栏的页面的文档申明 <!DOCTYPE html> 改成例如以下即可了 <!DOCTYPE H ...
- HDU TIANKENG’s rice shop(模拟)
HDU 4884 TIANKENG's rice shop 题目链接 题意:模拟题.转一篇题意 思路:就模拟就可以.注意每次炒完之后就能够接单 代码: #include <cstdio> ...
- 2015.04.23,外语,读书笔记-《Word Power Made Easy》 12 “如何奉承朋友” SESSION 33
1.eat, drink, and be merry 拉丁动词vivo(to live),加上名词vita(life),是许多重要英文词汇的来源. convivo是拉丁动词to live togeth ...