博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 3642 Get The Treasury (三维的扫描线)
阅读量:6215 次
发布时间:2019-06-21

本文共 4076 字,大约阅读时间需要 13 分钟。

题目大意:

给出N个立方体。

求一个三维空间中被包围三次的空间的体积之和。

思路分析:

发现Z的范围非常小。那么我们能够枚举Z轴,然后对 x y做扫描线。

并且不用枚举全部的Z ,仅仅须要将Z离散化之后枚举。

#include 
#include
#include
#include
#define maxn 2222#define debug puts("fuck!")#define lson num<<1,s,mid#define rson num<<1|1,mid+1,etypedef long long LL;using namespace std;inline void scanf_(int &num){ char in; bool neg=false; while(((in=getchar()) > '9' || in<'0') && in!='-') ; if(in=='-'){ neg=true; while((in=getchar()) >'9' || in<'0'); } num=in-'0'; while(in=getchar(),in>='0'&&in<='9') num*=10,num+=in-'0'; if(neg) num=0-num;}struct node{ int x1,y1,z1; int x2,y2,z2; void scan() { scanf_(x1); scanf_(y1); scanf_(z1); scanf_(x2); scanf_(y2); scanf_(z2); }}cube[maxn];struct line{ int s,e,h,type; bool operator < (const line &cmp)const { return h
=3) { len[num][3]=len[num][0]; len[num][1]=len[num][2]=0; } else if(cov[num]==2) { if(s==e) { len[num][1]=len[num][3]=0; len[num][2]=len[num][0]; } else { len[num][3]=len[num<<1][3]+len[num<<1|1][3]+len[num<<1][2]+len[num<<1|1][2] +len[num<<1][1]+len[num<<1|1][1]; len[num][2]=len[num][0]-len[num][3]; len[num][1]=0; } } else if(cov[num]==1) { if(s==e) { len[num][1]=len[num][0]; len[num][2]=len[num][3]=0; } else { len[num][3]=len[num<<1][3]+len[num<<1|1][3]+len[num<<1][2]+len[num<<1|1][2]; len[num][2]=len[num<<1][1]+len[num<<1|1][1]; len[num][1]=len[num][0]-len[num][2]-len[num][3]; } } else { len[num][3]=len[num<<1][3]+len[num<<1|1][3]; len[num][2]=len[num<<1][2]+len[num<<1|1][2]; len[num][1]=len[num<<1][1]+len[num<<1|1][1]; }}void build(int num,int s,int e){ len[num][0]=x[e+1]-x[s]; len[num][1]=len[num][2]=len[num][3]=0; cov[num]=0; if(s==e)return; int mid=(s+e)>>1; build(lson); build(rson);}void update(int num,int s,int e,int l,int r,int val){ if(l<=s && r>=e) { cov[num]+=val; if(cov[num]>=3) { len[num][3]=len[num][0]; len[num][1]=len[num][2]=0; } else if(cov[num]==2) { if(s==e) { len[num][1]=len[num][3]=0; len[num][2]=len[num][0]; } else { len[num][3]=len[num<<1][3]+len[num<<1|1][3]+len[num<<1][2]+len[num<<1|1][2] +len[num<<1][1]+len[num<<1|1][1]; len[num][2]=len[num][0]-len[num][3]; len[num][1]=0; } } else if(cov[num]==1) { if(s==e) { len[num][1]=len[num][0]; len[num][2]=len[num][3]=0; } else { len[num][3]=len[num<<1][3]+len[num<<1|1][3]+len[num<<1][2]+len[num<<1|1][2]; len[num][2]=len[num<<1][1]+len[num<<1|1][1]; len[num][1]=len[num][0]-len[num][2]-len[num][3]; } } else { len[num][3]=len[num<<1][3]+len[num<<1|1][3]; len[num][2]=len[num<<1][2]+len[num<<1|1][2]; len[num][1]=len[num<<1][1]+len[num<<1|1][1]; } return ; } int mid=(s+e)>>1; if(l<=mid)update(lson,l,r,val); if(r>mid)update(rson,l,r,val); pushup(num,s,e);}void solve(int kase){ build(1,0,cntx-2); LL ans=0; for(int i=0;i
z[i]) { scline[cnt].s=cube[j].x1; scline[cnt].e=cube[j].x2; scline[cnt].h=cube[j].y1; scline[cnt++].type=1; scline[cnt].s=cube[j].x1; scline[cnt].e=cube[j].x2; scline[cnt].h=cube[j].y2; scline[cnt++].type=-1; } } LL area=0; sort(scline,scline+cnt); for(int j=0;j

转载地址:http://bzpja.baihongyu.com/

你可能感兴趣的文章
【工具使用系列】关于 MATLAB 遗传算法与直接搜索工具箱,你需要知道的事
查看>>
Kali-linux Arpspoof工具
查看>>
PDF文档页面如何重新排版?
查看>>
基于http协议使用protobuf进行前后端交互
查看>>
bash腳本編程之三 条件判断及算数运算
查看>>
php cookie
查看>>
linux下redis安装
查看>>
弃 Java 而使用 Kotlin 的你后悔了吗?| kotlin将会是最好的开发语言
查看>>
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
StringBuilder用法小结
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
App开发中甲乙方冲突会闹出啥后果?H5 APP 开发可以改变现状吗
查看>>
jquery的checkbox,radio,select等方法总结
查看>>
Linux coredump
查看>>
Ubuntu 10.04安装水晶(Mercury)无线网卡驱动
查看>>
Myeclipes快捷键
查看>>