题目描述

题解:

和二维的比起来差不多。

但是这是四维偏序。

所以搞一下CDQ套CDQ。

CDQ是维度a已经有序,按维度b排序,然后将维度c存入一维数据结构。

所以我们在第一层CDQ中分治处理,将合法的前一半打标记。

然后进入第二层CDQ,处理打标记的点对没打标记的点的影响。

可以说是将两维压成一维。

想法仍然是容斥。

代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define N 50050
#define ll long long
inline int rd()
{
int f=,c=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){c=*c+ch-'';ch=getchar();}
return f*c;
}
struct node
{
int x,y,z,t,w,k,id;
int typ;
node(){}
node(int x,int y,int t,int w,int k,int i):x(x),y(y),t(t),w(w),k(k),id(i){}
}p[N<<],tmp[N<<],sec[N<<];
bool cmpx(node a,node b)
{
return a.x<b.x;
}
bool cmpid(node a,node b)
{
return a.id<b.id;
}
int cnt;
struct PR
{
int x,id;
PR(){}
PR(int x,int i):x(x),id(i){}
}Z[N<<];
bool cmp(PR a,PR b)
{
return a.x<b.x;
}
int T,Q,typ,tim;
int kkk[N<<],ct;
ll ans[N];
struct BIT
{
ll v[N<<];
void up(int x,ll d)
{
if(!x)return ;
while(x<(N<<))
v[x]+=d,x+=(x&-x);
}
ll down(int x)
{
if(!x)return ;
ll ret = 0ll;
while(x)
ret+=v[x],x-=(x&-x);
return ret;
}
}tr;
void init()
{
cnt=ct=;
tim=;
}
void ap(int x,int y,int z,int t,int w,int k)
{
cnt++;
p[cnt] = node(x,y,t,w,k,cnt);
Z[cnt] = PR(z,cnt);
}
void Sort(int l,int r)
{
int mid = (l+r)>>;
int i=l,j=mid+,k=l;
while(i<=mid&&j<=r)
{
while(i<=mid&&tmp[i].y<=tmp[j].y)
{
sec[k]=tmp[i];
i++,k++;
}
while(j<=r&&tmp[i].y>tmp[j].y)
{
sec[k]=tmp[j];
j++,k++;
}
}
while(i<=mid)
{
sec[k]=tmp[i];
i++,k++;
}
while(j<=r)
{
sec[k]=tmp[j];
j++,k++;
}
for(i=l;i<=r;i++)
tmp[i]=sec[i];
}
void cdq2(int l,int r)
{
if(l==r)return ;
int mid = (l+r)>>;
cdq2(l,mid);cdq2(mid+,r);
Sort(l,mid);Sort(mid+,r);
int i,j;
for(i=l,j=mid+;j<=r;j++)
{
while(i<=mid&&tmp[i].y<=tmp[j].y)
{
if(tmp[i].typ&&tmp[i].w)tr.up(tmp[i].z,tmp[i].w);
i++;
}
if(kkk[tmp[j].t]&&!tmp[j].typ)ans[kkk[tmp[j].t]]+=1ll*tmp[j].k*tr.down(tmp[j].z);
}
for(i=i-;i>=l;i--)
if(tmp[i].typ&&tmp[i].w)tr.up(tmp[i].z,-tmp[i].w);
}
void cdq1(int l,int r)
{
if(l==r)return ;
int mid = (l+r)>>;
cdq1(l,mid),cdq1(mid+,r);
sort(p+l,p+mid+,cmpx);
sort(p+mid+,p+r+,cmpx);
int i=l,j=mid+,k=l;
while(i<=mid&&j<=r)
{
while(i<=mid&&p[i].x<=p[j].x)
{
tmp[k]=p[i],tmp[k].typ=;
i++,k++;
}
while(j<=r&&p[i].x>p[j].x)
{
tmp[k]=p[j],tmp[k].typ=;
j++,k++;
}
}
while(i<=mid)
{
tmp[k]=p[i],tmp[k].typ=;
i++,k++;
}
while(j<=r)
{
tmp[k]=p[j],tmp[k].typ=;
j++,k++;
}
cdq2(l,r);
}
int main()
{
T=rd();
while(T--)
{
init();
Q = rd();
for(int ax,ay,az,bx,by,bz,i=;i<=Q;i++)
{
typ=rd();
if(typ==)
{
ax=rd(),ay=rd(),az=rd();
ap(ax,ay,az,tim,,);
}else
{
ax=rd(),ay=rd(),az=rd(),bx=rd(),by=rd(),bz=rd();
tim++,ct++;
kkk[tim]=ct;
ax--,ay--,az--;
ap(ax,ay,az,tim,,-);
ap(ax,ay,bz,tim,,);
ap(ax,by,az,tim,,);
ap(ax,by,bz,tim,,-);
ap(bx,ay,az,tim,,);
ap(bx,ay,bz,tim,,-);
ap(bx,by,az,tim,,-);
ap(bx,by,bz,tim,,);
tim++;
}
}
sort(Z+,Z++cnt,cmp);
for(int las=-,k=,i=;i<=cnt;i++)
{
if(las!=Z[i].x)
{
las = Z[i].x;
k++;
}
p[Z[i].id].z = k;
}
cdq1(,cnt);
for(int i=;i<=ct;i++)
printf("%I64d\n",ans[i]);
for(int i=;i<=ct;i++)
ans[i]=;
}
return ;
}

hdu5126 stars的更多相关文章

  1. HDU5126 stars【CDQ分治】*

    HDU5126 stars Problem Description John loves to see the sky. A day has Q times. Each time John will ...

  2. HDU5126 stars(CDQ分治)

    传送门 大意: 向三维空间中加点,询问一个三维区间中点的个数. 解题思路: 带修改CDQ,将修改和询问一起插入CDQ分治询问. (询问可以由8个前缀和加减操作实现) 其中第一层CDQ维护x有序. 第二 ...

  3. HDU5126 stars(cdq分治)

    传送门 题意: 先有两种操作,插入和查询,插入操作则插入一个点\((x,y,z)\),查询操作给出两个点\((x_1,y_1,z_1),(x_2,y_2,z_2)\),回答满足\(x_1\leq x\ ...

  4. [学习笔记]CDQ分治和整体二分

    序言 \(CDQ\) 分治和整体二分都是基于分治的思想,把复杂的问题拆分成许多可以简单求的解子问题.但是这两种算法必须离线处理,不能解决一些强制在线的题目.不过如果题目允许离线的话,这两种算法能把在线 ...

  5. 【HDU5126】 stars k-d树

    题目大意:有$m$个操作,分两种:在指定三维坐标内加入一个点,询问指定空间内点的数量. 其中$m≤5*10^{4},1≤x,y,z≤10^9$ 这题几乎就是裸的$k-d$树啊.我们动态维护一棵$k-d ...

  6. poj 2352 Stars 数星星 详解

    题目: poj 2352 Stars 数星星 题意:已知n个星星的坐标.每个星星都有一个等级,数值等于坐标系内纵坐标和横坐标皆不大于它的星星的个数.星星的坐标按照纵坐标从小到大的顺序给出,纵坐标相同时 ...

  7. POJ 2352 Stars(树状数组)

    Stars Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 30496   Accepted: 13316 Descripti ...

  8. 【POJ-2482】Stars in your window 线段树 + 扫描线

    Stars in Your Window Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11706   Accepted:  ...

  9. Java基础之在窗口中绘图——填充星型(StarApplet 2 filled stars)

    Applet程序. import javax.swing.*; import java.awt.*; import java.awt.geom.GeneralPath; @SuppressWarnin ...

随机推荐

  1. Androidstudio中添加jar包的方法

    在Androidstudio中添加一个jar包进去,怎么添加? 以下纯个人使用Androidstudio过程中的经验积累,要是有不足,望提出建议. 方法一: 先点击Androidstudio中的Pro ...

  2. HDU6069:Counting Divisors(因子数统计|区间筛)

    题意 计算\(\sum_{i=l}^kd(i^k)(d_i代表i的因子数)\) 分析 比赛搞了3个小时都没搞出来,有两个思维上的trick 1.要先遍历素数,再遍历[L,R],而不是枚举每个数,然后对 ...

  3. lightoj1079【背包】

    题意: 哈利波特抢银行... 给出n个银行,每个银行有a[i]百万和b[i]的风险.然后再给一个风险值P,不能超过P. 思路: 如果告诉你概率的小数的位数,可能这个就会不一样了... 慨率的计算,风险 ...

  4. GitHub笔记---邮箱访问错误

    GitHub地址太长,所以需要一个变量来保存 把远程仓库赋值给一个变量,以后就用就这变量代表这个地址 GitHub推送push 推送过程中发生一个小插曲,出现了错误,错误提示我复制过来吧 remote ...

  5. 【原创】《从0开始学Elasticsearch》—document的单/批量crud

    内容目录 1.新建文档2.查询文档3.修改文档4.删除文档 1.新建文档 1). 语法1,手动指定document 的id: PUT /index_name/type_name/id{    &quo ...

  6. 如何在VS2010的VC++ 基于对话框的MFC程序中添加菜单

    方法1:亲测 成功  转载自https://social.msdn.microsoft.com/Forums/vstudio/zh-CN/48338f6b-e5d9-4c0c-8b17-05ca3ef ...

  7. Python 教程资源

    1.廖雪峰的官方网站 http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001386 ...

  8. 谷歌编码风格内容,新建一个xml文件,复制进去就可以在eclipse里面用了,命名--eclipse-java-google-style.xml

    <?xml version="1.0" encoding="UTF-8" standalone="no"?> <profi ...

  9. json数组某个数值对应渲染

    当你统计某一年的某个值它对应的月份总数时,后台没有直接处理好,某个月对应某个值,这样会增加统计的负担,但当数据时这样的时候,在angularjs中时不能直接引用的. "data": ...

  10. 原创 Repeater radio 单选和多选混合

    希望高手朋友给我留下美好的意见,在此先感谢您! 前台代码repeater: <script src="../Scripts/jquery-1.9.1.js"></ ...