立方体交,自己写的莫名其妙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. mac java jdk 安装删除

    安装: http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 下载安装双击安装 卸载: ...

  2. 简易ATM机

    简易ATM机(代码如下): /* * 功能:简易银行系统 */package day8; import java.util.Scanner; /** * * @FengYan Huang Admini ...

  3. javascript 伪数组与标准数组

    伪数组 1. 是一个对象 2. 必须有length 属性,length 值是number 类型 3. 如果这个对象的length 不为0,那么必须要有按照下标存储的数据 标准数组 判断数据是否是标准数 ...

  4. poi-对于word的操作(一)

    2017-03-02 15:17:30 使用的jar包是poi 3.13 实现对word的存入,字体.颜色.大小的控制 测试类: package poi.test; public class Word ...

  5. Keil stm32 printf到Debug窗口

    使用JlinkV8+Keil41.在main.c输入以下代码 #include <stdio.h> #define ITM_Port8(n) (*((volatile unsigned c ...

  6. ettercap 模块使用

    Ettercap的过滤规则只能经过编译之后才能由-F参数载入到ettercap中使用. 编译过滤规则命令是:etterfilter filter.ecf -o filter.ef. 过滤规则的语法与C ...

  7. 开始学习tensorflow

    搭建神经网络: 准备数据 定义数据输入层 定义网络隐藏层和预测层 定义loss 表达式 选择optimizer使得loss 最小 import tensorflow as tf import nump ...

  8. dense prediction

    Dense prediction  fully convolutional network for sementic segmentation 先用feature extractor 提特征,然后再使 ...

  9. 矩阵NumPy

    常量: np.pi π 创建矩阵数组 import numpy as np # array=np.array([[1,2,3],[5,6,7]]) #定义一个2行3列的矩阵数组.2行=2维 # pri ...

  10. try 、catch 、finally 、throw 测试js错误

    try语句允许我们定义在执行时进行错误测试的代码块. catch 语句允许我们定义当 try 代码块发生错误时,所执行的代码块. finally 语句在 try 和 catch 之后无论有无异常都会执 ...