求点被多少个矩形覆盖
来源:互联网 发布:淘宝金冠店铺排行 编辑:程序博客网 时间:2024/04/27 23:56
有很多矩形,矩形可能会重叠,又有很多点分散在平面上,求每一个点被多少个矩形覆盖?
方法1:
参考:http://dongxicheng.org/structure/segment-tree/
总体思想是,如果线段树种的一个节点,就是这整个区间都在要插入的边内,则这个节点的计数加1
给一个n*n的方格棋盘,初始时每个格子都是白色。现在要刷M次黑色或白色的油漆。每次刷漆的区域都是一个平行棋盘边缘的矩形区域。
输入n,M,以及每次刷漆的区域和颜色,输出刷了M次之后棋盘上还有多少个棋格是白色。
[问题分析]
首先我们从简单入手,考虑一维的问题。即对于一个长度为n的白色线段,对它进行M次修改(每次更新某一子区域的颜色)。问最后还剩下的白色区域有多长。
对于这个问题,很容易想到建立一棵线段树的模型。复杂度为O(Mlgn)。
扩展到二维,需要把线段树进行调整,即首先在横坐标上建立线段树,它的每个节点是一棵建立在纵坐标上的线段树(即树中有树。称为二维线段树)。复杂度为O(M(logn)^2)。
方法2:
对矩形排序,如果左边界相同,按照右边界排序。
给点一个点(x,y)
二分查找左边界小于x的,然后就可以删除右边的矩形,对y也同理
- 求点被多少个矩形覆盖
- 数数有多少个矩形
- 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠2*n的大矩形,总共有多少种方法?
- 一个矩形块中有多少个正方形
- 【矩形覆盖问题分析】 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 日常工作常用数据库知识点汇总【不断完善。。】
- 11位素数
- android中用PopUpWindow自定义Menu菜单 带半透明效果
- 五种坐收财富的方法
- c语言实现各种排序算法(作业:点名册排序)
- 求点被多少个矩形覆盖
- 浅谈Ddos攻击攻击与防御
- Linux下curl的使用
- AUTOCAD 2004 不识别宋体,显示问号
- EasyUI 动态tab页界面小结
- 11个超棒的移动应用开发工具与方案
- SPFA算法
- Forms Error Messages
- 不借助编辑器自带的代码高亮工具(Syntaxhighlighte),生成完美格式的语法高亮代码