HDU 1828“Picture”(线段树+扫描线求矩形周长并)
•参考资料
•题意
给你 n 个矩形,求矩形并的周长;
•题解1(两次扫描线)
周长可以分成两部分计算,横线和竖线;
如何求解横线的所有并的长度呢?
和求矩阵面积并的做法一样,先将 x 离散化;
每次更新的时候,记录一下上次更新后的横线总长度;
ans += [现在这次总区间被覆盖的长度和上一次总区间被覆盖的长度之差的绝对值];
求解竖线的所有并的长度何求解横线的长度相同;
需要注意的是,在求解矩形面积并的时候,排序策略是按照 h 从小到大排序,并不需要考虑 h 相同的情况;
但是求矩形周长并的时候就不行了,必须得考虑 h 相同的情况下的排序策略;
以下例求解横线并的长度为例;
n=2
(2,1),(4,3)
(3,3),(4,5)
定义如下数据结构存储横线;struct Edge
{
int l,r;
int h;
int f;
bool operator < (const Edge &obj)const
{
return h < obj.h;
}
}e[maxn<<];假设与处理矩形面积并的排序策略相同,只考虑按 h 升序排列,那么排列后的数据为:
$e_{1}:\{l=2\ ,\ r=4\ ,\ h=1\ ,\ f=1 \}$
$e_{2}:\{l=2\ ,\ r=4\ ,\ h=3\ ,\ f=-1 \}$
$e_{3}:\{l=3\ ,\ r=4\ ,\ h=3\ ,\ f=1 \}$
$e_{1}:\{l=3\ ,\ r=4\ ,\ h=5\ ,\ f=-1 \}$
让我们手动模拟一下这个求解过程;
定义 ans 表示答案,len 表示当前更新后的横线并的总长度,pre 表示上一次更新后的 len 值;
初始化 ans=0,len=0,pre=0;
首先处理 $e_{1}$,update() 后,len = 2;
更新 ans += |len-pre| = 2 , pre=len=2;
处理 $e_{2}$,update() 后,len = 0;
此时,更新 ans += |len-pre| = 2+2 = 4 , pre=len=0,出现问题了是吧,因为来到此处的时候,ans=3才对;
继续向上更新, $e_{3}$,update() 后,len=1;
更新 ans += |len-pre| = 4+1 = 5 , pre=len=1;
$e_{4}$,update() 后,len=0;
更新 ans += |len-pre| = 5+1 = 6;
但是正确答案应该是 ans = 4;
多的 2 就是因为排序策略不当而产生的;
所以,当 h 相同的时候,应该先处理 f = 1 的边,即如果可以先加入边,那就优先执行加边操作;
所以,需要将 Edge 中的排序策略更改一下,改成如下模式:bool operator < (const Edge &obj)const
{
if(h != obj.h)
return h < obj.h;
return f > obj.f;
}(ps:f = 1 表示下边界,所以当 h 相同时,按照 f 降序排列)
到这,这道题就这么愉快的解决了;
•Code
HDU 1828“Picture”(线段树+扫描线求矩形周长并)的更多相关文章
- HDU 1828 Picture (线段树+扫描线)(周长并)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1828 给你n个矩形,让你求出总的周长. 类似面积并,面积并是扫描一次,周长并是扫描了两次,x轴一次,y ...
- poj 1177 --- Picture(线段树+扫描线 求矩形并的周长)
题目链接 Description A number of rectangular posters, photographs and other pictures of the same shape a ...
- HDU 1828 Picture (线段树:扫描线周长)
依然是扫描线,只不过是求所有矩形覆盖之后形成的图形的周长. 容易发现,扫描线中的某一条横边对答案的贡献. 其实就是 加上/去掉这条边之前的答案 和 加上/去掉这条边之后的答案 之差的绝对值 然后横着竖 ...
- hdu 1542(线段树+扫描线 求矩形相交面积)
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- poj 1177 Picture (线段树 扫描线 离散化 矩形周长并)
题目链接 题意:给出n个矩形,每个矩形给左下 和 右上的坐标,求围成的周长的长度. 分析: 首先感谢大神的博客,最近做题经常看大神的博客:http://www.cnblogs.com/kuangbin ...
- hdu1542 线段树扫描线求矩形面积的并
题意: 给你n个正方形,求出他们的所占面积有多大,重叠的部分只能算一次. 思路: 自己的第一道线段树扫描线题目,至于扫描线,最近会写一个总结,现在就不直接在这里写了,说下我的方 ...
- POJ 1177/HDU 1828 picture 线段树+离散化+扫描线 轮廓周长计算
求n个图矩形放下来,有的重合有些重合一部分有些没重合,求最后总的不规则图型的轮廓长度. 我的做法是对x进行一遍扫描线,再对y做一遍同样的扫描线,相加即可.因为最后的轮廓必定是由不重合的线段长度组成的, ...
- HDU 1542"Atlantis"(线段树+扫描线求矩形面积并)
传送门 •题意 给你 n 矩形,每个矩形给出你 $(x_1,y_1),(x_2,y_2)$ 分别表示这个矩形的左下角和右上角坐标: 让你求这 n 个矩形并的面积: 其中 $x \leq 10^{5} ...
- hdu 1828 Picture(线段树 || 普通hash标记)
http://acm.hdu.edu.cn/showproblem.php?pid=1828 Picture Time Limit: 6000/2000 MS (Java/Others) Mem ...
随机推荐
- 【转载】ubuntu下编写字符设备驱动程序-入门篇
在ubuntu初学驱动,觉得挺有用的. http://www.eefocus.com/jefby1990/blog/13-02/291628_c39b8.html
- jmeter测试APP时如何录制脚本
jmeter录制脚本需要注意的点: (1)手机和电脑需要处于一个局域网内(如手机和电脑所使用一个wifi) (2)设置手机代理的时候手机IP填写本机IP,端口号要和jmeter的相同,一般情况下端口号 ...
- 外贸电子商务网站之Prestashop paypal支付添加
1.在https://addons.prestashop.com/en/payment-card-wallet/1748-paypal.html 下载paypal支付模块 2.解压,复制到网站根目录- ...
- PHPCMS快速建站系列之邮箱验证
1. 登录163邮箱,->设置,开启POP3服务->把SMTP服务器地址复制到PHPCMS后台. 2.开启客户端授权密码 3.填写相关信息,.可以在测试邮箱填入邮箱地址测试
- 散列表(Hash Table)
散列表(hash table): 也称为哈希表. 根据wikipedia的定义:是根据关键字(Key value)而直接访问在内存存储位置的数据结构.也就是说,它通过把键值通过一个函数的计算,映射到表 ...
- map的三种遍历方法!
map的三种遍历方法! 集合的一个很重要的操作---遍历,学习了三种遍历方法,三种方法各有优缺点~~ /* * To change this template, choose Tools | Te ...
- 使用 Markdown Flow 画流程图
使用 Markdown Flow 画流程图 好处是可以方便的使用 Git 管理版本 st=>start: 开始 e=>end: 结束 c1=>condition: A c2=> ...
- ubuntu 使用glfw.h 出现函数无法调用
最近在学习在Ubuntu下使用qt进行opengl开发,使用到了glfw这个库.我安装官网的编译和安装方法进行了配置安装,在usr/local/include的下产生了glfw.h文件. 于是我在我的 ...
- SDUT-3343_数据结构实验之二叉树四:(先序中序)还原二叉树
数据结构实验之二叉树四:(先序中序)还原二叉树 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给定一棵二叉树的先序遍历 ...
- 解决大数据难题 阿里云MaxCompute获科技大奖
摘要: 据介绍,MaxCompute(大规模分布式的数据计算平台)是国内最早自研的大数据计算平台之一,主要应用于大规模数据处理场景.目前,这项源自浙江.解决世界级难题的成果已拥有EB(百京)级别的数据 ...