传送门

•参考资料

  [1]:算法总结:【线段树+扫描线】&矩形覆盖求面积/周长问题(HDU 1542/HDU 1828)

•题意

  给你 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

  HDU1828.cpp

HDU 1828“Picture”(线段树+扫描线求矩形周长并)的更多相关文章

  1. HDU 1828 Picture (线段树+扫描线)(周长并)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1828 给你n个矩形,让你求出总的周长. 类似面积并,面积并是扫描一次,周长并是扫描了两次,x轴一次,y ...

  2. poj 1177 --- Picture(线段树+扫描线 求矩形并的周长)

    题目链接 Description A number of rectangular posters, photographs and other pictures of the same shape a ...

  3. HDU 1828 Picture (线段树:扫描线周长)

    依然是扫描线,只不过是求所有矩形覆盖之后形成的图形的周长. 容易发现,扫描线中的某一条横边对答案的贡献. 其实就是 加上/去掉这条边之前的答案 和 加上/去掉这条边之后的答案 之差的绝对值 然后横着竖 ...

  4. hdu 1542(线段树+扫描线 求矩形相交面积)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  5. poj 1177 Picture (线段树 扫描线 离散化 矩形周长并)

    题目链接 题意:给出n个矩形,每个矩形给左下 和 右上的坐标,求围成的周长的长度. 分析: 首先感谢大神的博客,最近做题经常看大神的博客:http://www.cnblogs.com/kuangbin ...

  6. hdu1542 线段树扫描线求矩形面积的并

    题意:       给你n个正方形,求出他们的所占面积有多大,重叠的部分只能算一次. 思路:       自己的第一道线段树扫描线题目,至于扫描线,最近会写一个总结,现在就不直接在这里写了,说下我的方 ...

  7. POJ 1177/HDU 1828 picture 线段树+离散化+扫描线 轮廓周长计算

    求n个图矩形放下来,有的重合有些重合一部分有些没重合,求最后总的不规则图型的轮廓长度. 我的做法是对x进行一遍扫描线,再对y做一遍同样的扫描线,相加即可.因为最后的轮廓必定是由不重合的线段长度组成的, ...

  8. HDU 1542"Atlantis"(线段树+扫描线求矩形面积并)

    传送门 •题意 给你 n 矩形,每个矩形给出你 $(x_1,y_1),(x_2,y_2)$ 分别表示这个矩形的左下角和右上角坐标: 让你求这 n 个矩形并的面积: 其中 $x \leq 10^{5} ...

  9. hdu 1828 Picture(线段树 || 普通hash标记)

    http://acm.hdu.edu.cn/showproblem.php?pid=1828 Picture Time Limit: 6000/2000 MS (Java/Others)    Mem ...

随机推荐

  1. web服务器与tomcat

    web服务器与tomcat 服务器分类: 硬件服务器和软件服务器 web服务器: 提供资源供别人访问 web: 网页的意思,资源. web资源分类: 动态的web资源:内容有可能发生改变的 静态的we ...

  2. python 匹配集合与补集

  3. 虚幻UE4的后处理特效介绍 http://www.52vr.com/thread-31215-1-1.html

    转载 虚幻UE4提供了后处理特效的功能,可以实现景深,光溢出,色调调整,饱和度等等.要使用虚幻4的后处理,就一定要用到PostProcessVolumn,这是一种特殊的体积,可以放置在场景中的任何位置 ...

  4. U盘安装win7 raid设置

    需要先安装驱动!  大白菜U盘安装界面有一个选择驱动的选项,选择驱动即可.Intel_ESRT2_Windows_signed_DRV_v16.03.2014.1127

  5. 【md5加密】不可逆之简单例子原理

    import hashlib def md5_get(data): ret = hashlib.md5("gfdwuqmo@md1.".encode("utf-8&quo ...

  6. Java安全——密钥那些事

    标签(空格分隔): Java 安全 概念 密钥是加密算法不可缺少的部分.密钥在安全体系中至关重要,正如其名,私密的钥匙,打开安全的大门.密钥分两种:对称密钥和非对称密钥.非对称密钥里又包含公开密钥和私 ...

  7. day39-Spring 16-Spring的JDBC模板:设置参数到属性文件

    <?xml version="1.0" encoding="UTF-8"?> <!-- 引入beans的头 --> <beans ...

  8. 阿里巴巴资深技术专家无相:我们能从 InteliJ IDEA 中学到什么?

    本文来源于阿里巴巴资深技术专家无相在内网的分享,阿里巴巴中间件受权发布. 最近因为工作的关系,要将 Eclipse 的插件升级为 IDEA 插件.升级过程中,对 IDEA 插件做了些学习和研究,希望通 ...

  9. bzoj1624 寻宝之路

    Description     农夫约翰正驾驶一条小艇在牛勒比海上航行.     海上有N(1≤N≤100)个岛屿,用1到N编号.约翰从1号小岛出发,最后到达N号小岛.一张藏宝图上说,如果他的路程上经 ...

  10. ffmpeg在iOS的使用 - iFrameExtractor源码解析

    http://www.cocoachina.com/ios/20150914/13284.html iFrameExtractor地址:https://github.com/lajos/iFrameE ...