博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
求点被多少个矩形覆盖
阅读量:4155 次
发布时间:2019-05-25

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

有很多矩形,矩形可能会重叠,又有很多点分散在平面上,求每一个点被多少个矩形覆盖?

方法1:

参考:

总体思想是,如果线段树种的一个节点,就是这整个区间都在要插入的边内,则这个节点的计数加1

给一个n*n的方格棋盘,初始时每个格子都是白色。现在要刷M次黑色或白色的油漆。每次刷漆的区域都是一个平行棋盘边缘的矩形区域。

输入n,M,以及每次刷漆的区域和颜色,输出刷了M次之后棋盘上还有多少个棋格是白色。

[问题分析]

首先我们从简单入手,考虑一维的问题。即对于一个长度为n的白色线段,对它进行M次修改(每次更新某一子区域的颜色)。问最后还剩下的白色区域有多长。

对于这个问题,很容易想到建立一棵线段树的模型。复杂度为O(Mlgn)。

扩展到二维,需要把线段树进行调整,即首先在横坐标上建立线段树,它的每个节点是一棵建立在纵坐标上的线段树(即树中有树。称为二维线段树)。复杂度为O(M(logn)^2)。

方法2:

对矩形排序,如果左边界相同,按照右边界排序。

给点一个点(x,y)

二分查找左边界小于x的,然后就可以删除右边的矩形,对y也同理

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

你可能感兴趣的文章
word或者pdf文件全部保存为图片的方法
查看>>
VS2010下SQLite3生成lib库文件
查看>>
sqlite3的helloworld
查看>>
MFC下支持中文的SQLite3封装类使用
查看>>
简单高效的多线程日志类
查看>>
研华USB4711A采集卡高速中断模式采集总结
查看>>
从零起步CMFCToolBar用法详解
查看>>
CMFCRibbonStatusBar用法
查看>>
CMFCListCtrl控件使用
查看>>
CMFCControlRendererInfo类的参数
查看>>
史上最详细MFC调用mapX5.02.26步骤(附地图测试GST文件)
查看>>
CMFCShellListCtrl使用方法
查看>>
mapnik的demo运行
查看>>
python支持下的mapnik安装
查看>>
The Android ION memory allocator, DMABUF is mentioned as well
查看>>
spin_lock and mutex_lock
查看>>
C与C++互相调用
查看>>
map server
查看>>
MTK Android 开发笔记
查看>>
大一大二ACM训练时,建立的一个博客,专门用来写题解的
查看>>