hdu3642扫描线 长方体
立方体交,自己写的莫名其妙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扫描线 长方体的更多相关文章
- HDU3642 Get The Treasury —— 求矩形交体积 线段树 + 扫描线 + 离散化
题目链接:https://vjudge.net/problem/HDU-3642 Jack knows that there is a great underground treasury in a ...
- hdu3642 Get The Treasury 线段树--扫描线
Jack knows that there is a great underground treasury in a secret region. And he has a special devic ...
- Get The Treasury【HDU-3642】【扫描线】
题目链接 题目给出的是N个体积块,问的是有多少体积重叠了3次及以上? 那么就是怎么处理体积这样子的问题了,看到Z的种类不多的时候,就想着从Z离散化的角度去考虑这个问题了,然后就是怎样子去处理面积了,这 ...
- 线段树总结 (转载 里面有扫描线类 还有NotOnlySuccess线段树大神的地址)
转载自:http://blog.csdn.net/shiqi_614/article/details/8228102 之前做了些线段树相关的题目,开学一段时间后,想着把它整理下,完成了大牛NotOnl ...
- hdu 3642 Get The Treasury(扫描线)
pid=3642" style="">题目链接:hdu 3642 Get The Treasury 题目大意:三维坐标系,给定若干的长方体,问说有多少位置被覆盖3次 ...
- hdu3255扫描线:带权面积交转体积交
手贱把i打成j,调了半天 /* 面积并转体积并,长方体高度为作物价格 算体积并:在笛卡尔坐标系的y轴上建立线段树cnt记录区间被完全覆盖的次数,sum记录区间被覆盖的总长度 以平行于xoy的平面从下往 ...
- HDU 3642 - Get The Treasury - [加强版扫描线+线段树]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3642 Time Limit: 10000/5000 MS (Java/Others) Memory L ...
- hdu3255 线段树扫描线求体积
题意: 给你n个矩形,每个矩形上都有一个权值(该矩形单位面积的价值),矩形之间可能重叠,重叠部分的权值按照最大的算,最后问这n个矩形组成的图形的最大价值. 思路: 线段树扫描线 ...
- 【Codeforces720D】Slalom 线段树 + 扫描线 (优化DP)
D. Slalom time limit per test:2 seconds memory limit per test:256 megabytes input:standard input out ...
随机推荐
- 反射attr以及模块动态导入
一.实现自省的四个函数 1.hasattr判断一个对象中有没有一个name字符串对应的方法或属性 class BlackMedium: feture="Ugly" def __in ...
- java.lang.ClassCastException:java.util.LinkedHashMap不能转换为com.testing.models.Account
ObjectMapper mapper=new ObjectMapper();POJO pojo = mapper.convertValue(singleObject, POJO.class);
- JAVA分布式架构的演进
系统架构演化历程-初始阶段架构 初始阶段 的小型系统 应用程序.数据库.文件等所有的资源都在一台服务器上通俗称为LAMP 特征:应用程序.数据库.文件等所有的资源都在一台服务器上. 描述:通常服务器操 ...
- jenkins Pipeline 使用
说明 Jenkins pipeline 是一套插件,支持将连续输送管道实施和整合到Jenkins.Pipeline提供了一组可扩展的工具,用于通过管道DSL为代码创建简单到复杂的传送流水线.他目前支持 ...
- Java基础-考察JVM内部结构的常用工具介绍
Java基础-考察JVM内部结构的常用工具介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我们可以通过jvisualvm.exe考察jvm内部结构.而jvisualvm.exe ...
- Exception异常转String【转】
把异常的栈轨迹以String形式返回 /** * 把异常的栈轨迹以String形式返回,而不是直接打印到console * @author King * @time 2015-04-29 * @ret ...
- python 代码模板
命令[python3 -m pydoc -p 1234] 通过http://localhost:1234来访问查看文档 # -*- coding: utf-8 -*-""&qu ...
- Keil软仿真STM32
当使用Keil软仿真STM32时,SystemClock设置为72MHz,使用循环延迟1s钟,实际时间明显大于1S钟,但是Keil调试窗口显示的确实是1s钟//毫秒级的延时void delay_ms( ...
- Ribbon实现Office开始菜单
Ribbon实现Office开始菜单 界面效果: 首先:在主窗体上拖入popupMenu控件和imageCollection控件 然后选中popupMenu点击三角,再点击Run Designer在弹 ...
- Linux - DDOS检测
netstat netstat -na #显示所有连接到服务器的活跃的网络连接 netstat -an | grep : | sort # 只显示连接到80段口的活跃的网络连接,80是http端口, ...