立方体交,自己写的莫名其妙MLE了,不知道为什么

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define maxn 2010
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define ll long long
struct cube{
int x1,y1,z1,x2,y2,z2;
cube(){}
cube(int a,int b,int c,int d,int e,int f):
x1(a),y1(b),z1(c),x2(d),y2(e),z2(f){}
}cubes[maxn];
struct seg{//水平横线段
int l,r,h,d;
seg(){}
seg(int l,int r,int h,int d):l(l),r(r),h(h),d(d){}
bool operator<(const seg & a)const
{ return h<a.h; }
}segs[maxn];
int tots;
int y[maxn],z[maxn],tot,toty,totz;//y轴,z轴上的数据
int len1[maxn<<],len2[maxn<<],len3[maxn<<];//线段树区间被覆盖了1,2,3次的长度
int cnt[maxn<<];//区间被完全覆盖的次数
inline void pushup(int rt,int l,int r){
if(cnt[rt]>=){
len3[rt]=y[r+]-y[l];
len2[rt]=len1[rt]=;
}
else if(cnt[rt]==){
len1[rt]=;
len2[rt]=y[r+]-y[l];
if(l==r) len3[rt]=;//没有子区间的情况
else {
len3[rt]=len3[rt<<]+len3[rt<<|]+len2[rt<<]+len2[rt<<|]+len1[rt<<]+len1[rt<<|];
len2[rt]-=len3[rt];
}
}
else if(cnt[rt]==){
len1[rt]=y[r+]-y[l];
if(l==r) len3[rt]=len2[rt]=;//没有子区间的情况
else {
len3[rt]=len3[rt<<]+len3[rt<<|]+len2[rt<<]+len2[rt<<|];
len2[rt]=len1[rt<<]+len1[rt<<|];
len1[rt]-=len2[rt]+len3[rt];
}
}
else {//cnt[rt]==0
if(l==r) len3[rt]=len2[rt]=len1[rt]=;
else {
len3[rt]=len3[rt<<]+len3[rt<<|];
len2[rt]=len2[rt<<]+len2[rt<<|];
len1[rt]=len1[rt<<]+len1[rt<<|];
}
}
}
void update(int L,int R,int c,int l,int r,int rt){
if(L<=l && R>=r){
cnt[rt]+=c;
pushup(rt,l,r);
return;
}
int m=l+r>>;
if(L<=m) update(L,R,c,lson);
if(R>m) update(L,R,c,rson);
pushup(rt,l,r);
}
void init(){
tot=toty=totz=tots=;
memset(y,,sizeof y);
memset(z,,sizeof z);
memset(len1,,sizeof len1);
memset(len2,,sizeof len2);
memset(len3,,sizeof len3);
memset(cnt,,sizeof cnt);
}
int main(){
int T,n;
scanf("%d",&T);
for(int tt=;tt<=T;tt++){
init();
scanf("%d",&n);
for(int i=;i<=n;i++){
int a,b,c,d,e,f;
scanf("%d%d%d%d%d%d",&a,&b,&c,&d,&e,&f);
cubes[i]=cube(a,b,c,d,e,f);
y[tot]=b;z[tot++]=c;
y[tot]=e;z[tot++]=f;
}
if(n<) {puts("");continue;} sort(y,y+tot);toty=unique(y,y+tot)-y;
sort(z,z+tot);totz=unique(z,z+tot)-z;
ll res=;
for(int i=;i<totz-;i++){
tots=;
for(int j=;j<=n;j++)
if(cubes[j].z1<=z[i] && cubes[j].z2>=z[i+]){
segs[tots++]=seg(cubes[j].x1,cubes[j].x2,cubes[j].y1,);
segs[tots++]=seg(cubes[j].x1,cubes[j].x2,cubes[j].y2,-);
}
sort(segs,segs+tots);//将水平横线段排序
for(int j=;j<tots;j++){//将这些边更新到线段树中
if(j!=) res+=(z[i+]-z[i])*(segs[j].h-segs[j-].h)*len3[];
int L=lower_bound(y,y+toty,segs[j].l)-y;
int R=lower_bound(y,y+toty,segs[j].r)-y-;
update(L,R,segs[j].d,,toty,);//为什么要计算在前更新在后?
}
}
printf("%lld\n",res);
}
return ;
}

kuangbin的板子是可以过的。。

hdu3642扫描线 长方体的更多相关文章

  1. HDU3642 Get The Treasury —— 求矩形交体积 线段树 + 扫描线 + 离散化

    题目链接:https://vjudge.net/problem/HDU-3642 Jack knows that there is a great underground treasury in a ...

  2. hdu3642 Get The Treasury 线段树--扫描线

    Jack knows that there is a great underground treasury in a secret region. And he has a special devic ...

  3. Get The Treasury【HDU-3642】【扫描线】

    题目链接 题目给出的是N个体积块,问的是有多少体积重叠了3次及以上? 那么就是怎么处理体积这样子的问题了,看到Z的种类不多的时候,就想着从Z离散化的角度去考虑这个问题了,然后就是怎样子去处理面积了,这 ...

  4. 线段树总结 (转载 里面有扫描线类 还有NotOnlySuccess线段树大神的地址)

    转载自:http://blog.csdn.net/shiqi_614/article/details/8228102 之前做了些线段树相关的题目,开学一段时间后,想着把它整理下,完成了大牛NotOnl ...

  5. hdu 3642 Get The Treasury(扫描线)

    pid=3642" style="">题目链接:hdu 3642 Get The Treasury 题目大意:三维坐标系,给定若干的长方体,问说有多少位置被覆盖3次 ...

  6. hdu3255扫描线:带权面积交转体积交

    手贱把i打成j,调了半天 /* 面积并转体积并,长方体高度为作物价格 算体积并:在笛卡尔坐标系的y轴上建立线段树cnt记录区间被完全覆盖的次数,sum记录区间被覆盖的总长度 以平行于xoy的平面从下往 ...

  7. HDU 3642 - Get The Treasury - [加强版扫描线+线段树]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3642 Time Limit: 10000/5000 MS (Java/Others) Memory L ...

  8. hdu3255 线段树扫描线求体积

    题意:       给你n个矩形,每个矩形上都有一个权值(该矩形单位面积的价值),矩形之间可能重叠,重叠部分的权值按照最大的算,最后问这n个矩形组成的图形的最大价值. 思路:       线段树扫描线 ...

  9. 【Codeforces720D】Slalom 线段树 + 扫描线 (优化DP)

    D. Slalom time limit per test:2 seconds memory limit per test:256 megabytes input:standard input out ...

随机推荐

  1. Harbor镜像清理

    目录 清理UI中的镜像 清理镜像释放空间 docker镜像仓库中镜像的清理,一直是个比较麻烦的事情.尤其是在测试环境当中,每天都会有大量的构建.由此会产生大量的历史镜像,而这些镜像,大多数都没有用. ...

  2. POJ1185 状压dp(二进制//三进制)解法

    很显然这是一道状压dp的题目 由于每个最优子结构和前两行有关,一个显而易见的想法是用三维dp[i][j][k]用来记录在第i行下为j状态,i - 1行为k状态时的最大值,然而dp[100][1 < ...

  3. transform顺序浅谈

    有用过transform的小伙伴们可能都会遇到一些问题,发现transform得到的结果往往不是我们所想的 例如scale(2,1) rotate(30deg) ,我们预想的结果是一个先放大的元素,然 ...

  4. 学习windows编程 day3 之窗口绘画一:点线绘制

    #include <windows.h> #include <math.h> LRESULT CALLBACK WndProc(HWND hwnd, UINT message, ...

  5. webpack配置说明

    webpack是一个现代JavaScript应用程序的静态模块打包器. 它有几个核心概念: 一.entry(入口) 指示webpack应该使用哪个模块,来作为构建其内部依赖图的开始, 可以在webpa ...

  6. java基本数据类型,访问控制符,运算符执行顺序

    1.java数据类型 内置数据类型:boolean(1),  byte(8), char(16), short(8), int(32), long(64), float(32), double(64) ...

  7. 序列化时提示There was an error reflecting type 'System.Collections.Generic.List`1

    序列化xml文件到List中,非win10下出现了这个错误,但是在win10下正常.经过仔细的研究,发现是序列化工具类不能使用Static.去掉Static即可.

  8. Spring第一个helloWorld

    Spring 简介: 轻量级:Spring是非侵入性的-基于Spring开发的应用中的对象可以不依赖于Spring的API 依赖注入(DI—dependdency injection.IOC) 面向切 ...

  9. spfa判负环

    bfs版spfa void spfa(){ queue<int> q; ;i<=n;i++) dis[i]=inf; q.push();dis[]=;vis[]=; while(!q ...

  10. QPushButton按钮

    需要 from PyQt5.QtWidgets import QPushButton继承 QAbstractButton 创建按钮控件:QPushButton() 创建一个无父控件的按钮控件QPush ...