hdu 3265 线段树扫描线(拆分矩形)
题意:
给你n个矩形,每个矩形上都有一个矩形的空洞,所有的矩形都是平行于x,y轴的,最后问所有矩形的覆盖面积是多少。
思路:
是典型的矩形覆盖问题,只不过每个矩形上多了一个矩形洞,我的做法是吧当前的矩形分成四个小的矩形,然后用线段树的扫描线扫一遍就ok了,记得要用INT64 ,自己没注意这个问题wa了一次。
#include<stdio.h>
#include<string.h>
#include<algorithm> #define N 300000
#define lson l ,mid ,t << 1
#define rson mid ,r ,t << 1 | 1
using namespace std; typedef struct
{
__int64 l ,r ,h ,mk;
}EDGE; __int64 len[N] ,cnt[N];
EDGE edge[N*2]; bool camp(EDGE a ,EDGE b)
{
return a.h < b.h || a.h == b.h && a.mk > b.mk;
} void Pushup(__int64 l ,__int64 r ,__int64 t)
{
if(cnt[t]) len[t] = r - l;
else if(l + 1 == r) len[t] = 0;
else len[t] = len[t<<1] + len[t<<1|1];
} void Update(__int64 l ,__int64 r ,__int64 t ,__int64 a ,__int64 b ,__int64 c)
{
//printf("%d %d %d\n" ,l ,r ,t);
if(l == a && r == b)
{
cnt[t] += c;
Pushup(l ,r ,t);
return;
}
__int64 mid = (l + r) >> 1;
if(b <= mid) Update(lson ,a ,b ,c);
else if(a >= mid) Update(rson ,a ,b ,c);
else
{
Update(lson ,a ,mid ,c);
Update(rson ,mid ,b ,c);
}
Pushup(l ,r ,t);
} __int64 abss(__int64 x)
{
return x < 0 ? -x : x;
} int main ()
{
__int64 i ,j ,n ,x1 ,x2 ,x3 ,x4 ,y1 ,y2 ,y3 ,y4 ,id;
__int64 xx1 ,xx2 ,yy1 ,yy2;
while(~scanf("%I64d" ,&n) && n)
{
for(id = 0 ,i = 1 ;i <= n ;i ++)
{
scanf("%I64d %I64d %I64d %I64d %I64d %I64d %I64d %I64d" ,&x1 ,&y1 ,&x2 ,&y2 ,&x3 ,&y3 ,&x4 ,&y4);
x1 ++ ,y1 ++ ,x2 ++ ,y2 ++ ,x3 ++ ,y3 ++ ,x4 ++ ,y4 ++;
// x1 y2 x2 y4
xx1 = x1 ,xx2 = x2 ,yy1 = y2 ,yy2 = y4;
if(abss(xx1 - xx2) && abss(yy1 - yy2))
{
edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy1 ,edge[id].mk = 1; edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy2 ,edge[id].mk = -1;
}
// x1 y3 x2 y1
xx1 = x1 ,xx2 = x2 ,yy1 = y3 ,yy2 = y1;
if(abss(xx1 - xx2) && abss(yy1 - yy2))
{
edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy1 ,edge[id].mk = 1; edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy2 ,edge[id].mk = -1;
} // x1 y4 x3 y3
xx1 = x1 ,xx2 = x3 ,yy1 = y4 ,yy2 = y3;
if(abss(xx1 - xx2) && abss(yy1 - yy2))
{
edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy1 ,edge[id].mk = 1; edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy2 ,edge[id].mk = -1;
} // x4 y4 x2 y3
xx1 = x4 ,xx2 = x2 ,yy1 = y4 ,yy2 = y3;
if(abss(xx1 - xx2) && abss(yy1 - yy2))
{
edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy1 ,edge[id].mk = 1; edge[++id].l = xx1;
edge[id].r = xx2 ,edge[id].h = yy2 ,edge[id].mk = -1;
}
}
sort(edge + 1 ,edge + id + 1 ,camp);
__int64 Ans = 0;
memset(len ,0 ,sizeof(len));
memset(cnt ,0 ,sizeof(cnt));
edge[0].h = edge[1].h;
for(i = 1 ;i <= id ;i ++)
{
Ans += len[1] * (edge[i].h - edge[i-1].h);
Update(1 ,50001,1 ,edge[i].l ,edge[i].r ,edge[i].mk); }
printf("%I64d\n" ,Ans);
}
return 0;
}
hdu 3265 线段树扫描线(拆分矩形)的更多相关文章
- hdu 4419 线段树 扫描线 离散化 矩形面积
//离散化 + 扫描线 + 线段树 //这个线段树跟平常不太一样的地方在于记录了区间两个信息,len[i]表示颜色为i的被覆盖的长度为len[i], num[i]表示颜色i 『完全』覆盖了该区间几层. ...
- HDU 1828“Picture”(线段树+扫描线求矩形周长并)
传送门 •参考资料 [1]:算法总结:[线段树+扫描线]&矩形覆盖求面积/周长问题(HDU 1542/HDU 1828) •题意 给你 n 个矩形,求矩形并的周长: •题解1(两次扫描线) 周 ...
- hdu 4052 线段树扫描线、奇特处理
Adding New Machine Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 1828 线段树扫描线(周长)
Picture Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- POJ-1151-Atlantis(线段树+扫描线+离散化)[矩形面积并]
题意:求矩形面积并 分析:使用线段树+扫描线...因为坐标是浮点数的,因此还需要离散化! 把矩形分成两条边,上边和下边,对横轴建树,然后从下到上扫描上去,用col表示该区间有多少个下边,sum代表该区 ...
- hdu 5091(线段树+扫描线)
上海邀请赛的一道题目,看比赛时很多队伍水过去了,当时还想了好久却没有发现这题有什么水题的性质,原来是道成题. 最近学习了下线段树扫描线才发现确实是挺水的一道题. hdu5091 #include &l ...
- HDU 5107 线段树扫描线
给出N个点(x,y).每一个点有一个高度h 给出M次询问.问在(x,y)范围内第k小的高度是多少,没有输出-1 (k<=10) 线段树扫描线 首先离散化Y坐标,以Y坐标建立线段树 对全部的点和询 ...
- hdu1542 线段树扫描线求矩形面积的并
题意: 给你n个正方形,求出他们的所占面积有多大,重叠的部分只能算一次. 思路: 自己的第一道线段树扫描线题目,至于扫描线,最近会写一个总结,现在就不直接在这里写了,说下我的方 ...
- HDU 5091 线段树扫描线
给出N个点.和一个w*h的矩形 给出N个点的坐标,求该矩形最多能够覆盖多少个点 对每一个点point(x.y)右边生成相应的点(x+w,y)值为-1: 纵向建立线段树,从左到右扫描线扫一遍.遇到点则用 ...
随机推荐
- Java基础学习--集合
集合 List集合的特点 1.有序的数据集合,存储元素和取出元素的顺序是一致的(存储123,取出123) 2.有索引,包含了一些带索引的方法 3.允许存储重复的元素 List接口中带索引的方法 add ...
- unittest系列(三)unittest用例如何执行
在前面的分享中,我们分别讲了unittest的相关流程以及相关断言,那么很多人,都会问了unittest的用例,应该如何执行呢,这次,我们就来看看,unittest用例如何执行.首先,我们可以使用py ...
- List的主要实现类
//ArrayList:List的主要实现类 /* * List中相对于Collection,新增加的方法 * void add(int index, Object ele):在指定的索引位置inde ...
- BZOJ_2115 [Wc2011] Xor 【图上线性基】
一.题目 [Wc2011] Xor 二.分析 比较有意思的一题,这里也学到一个结论:$1$到$N$的任意一条路径异或和,可以是一个任意一条$1$到$N$的异或和与图中一些环的异或和组合得到.因为一个数 ...
- 安全计算环境之剩余信息保护-windows
参考https://blog.csdn.net/ubjewen/article/details/107587951 应保证鉴别信息所在的存储空间被释放或重新分配前得到完全清除 交互式登录: 之前登录到 ...
- 2020-2021 ACM-ICPC, Asia Seoul Regional Contest
C. Dessert Café: 题意: 给你一个N个节点的树,树上有m个房子,问树上有几个节点是在两个房子之间的. 思路:我们发现只要是该节点的子树里包括了所有节点或者只有一个节点,那么这个结点肯定 ...
- ch2_8_1求解n阶螺旋矩阵问题
思路:循环输出,注意边界控制 import java.util.Scanner; public class ch2_8_1求解n阶螺旋矩阵问题 { public static void main(St ...
- .NET 开源配置组件 AgileConfig 初体验
介绍 在微服务大行其道的今天,系统会被拆分成多个模块,作为单独的服务运行,同时为了集中化管理,我们还需要日志中心,配置中心等,很多开发人员可能更熟悉 ApolloConfig,这个组件功能也很完善,d ...
- 记录给树莓派刷Raspberry Pi OS(Raspbian)系统的配置流程
准备材料 树莓派(一定要贴散热片,最好再加个小风扇) TF内存卡 (记得选传输规范为Class10标准的) 读卡器 电脑(这里我使用的电脑是Windows系统,其它系统可能与下面的步骤有出入,还望悉知 ...
- redis常用数据类型对应的数据结构
redis的数据类型都是通过多种数据结构来实现,主要是出于时间和空间的考虑,当数据量小的时候通过数组下标访问最快,占用内存最小[压缩列表是数组的变种,允许存储的数据大小不同] 因为数组需要占用连续的内 ...