- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
给定一个凸多边形作为 n 个顶点的逆时针列表,给出 O(lgn) 算法来确定给定的点是否在多边形内。假设基本操作需要 O(1)。
我认为一个方向是:如果一个点在凸多边形内,那么这些点与所有顶点或边之间的特殊关系是什么?另外,我猜这里的技巧是使算法lgn的凸多边形。
最佳答案
我所知道的这个问题的唯一解决方案需要 O(n)
多边形预处理时间。然后针对预处理多边形的每个查询点在 O(lg n)
中处理。时间。
就拿一点P
在多边形内部(我们称之为“极点”),并为每个顶点绘制一条从 P
退出的射线并通过顶点。将此视为原点位于 P
的极坐标系。 ,整个极平面被这些射线分割为扇区。现在,给定您的查询点,您只需要将其转换为以我们极点为原点的极坐标 P
.然后只需执行二分查找来确定包含查询点的特定扇区。扇区内的最终内部/外部检查(点与边缘侧测试)是微不足道的 O(1)
手术。每个查询都在 O(lg n)
中处理二分查找所需的时间。
这种方法实际上适用于更多类的多边形,而不仅仅是凸多边形。它涵盖了所谓的星形多边形类,即具有一个点的多边形,从这个点可以“看到”或“观察”多边形的整个内部。O(n)
预处理时间来自于需要提前确定极点的位置。
附言我不得不考虑更一般的情况。如果您的多边形是凸多边形,您可以简单地使用它的任何顶点作为极点。这样你就会得到一个 O(lg n)
算法,不需要预处理。
关于computational-geometry - 确定给定点是否在多边形内,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5223909/
当我在定点 Z3Py 中启用解释生成选项时,我收到包含以下消息的核心转储。 Error setting 'DL_GENERATE_EXPLANATIONS', reason: unknown opti
我正在开发一些代码,可以从 HW 获取浮点或定点数据。目前我们将其作为 float 。 底层API都是定点的。所以我们必须将数据作为定点传回。我们使用的算法是 Cholesky。我想知道为什么我们必须
我有一个关于在 MATLAB 中为 Texas Instruments TMS320C64xx DSP 编写算法的问题: 我在 MATLAB 中草率地实现了我的过滤器。我的目标是使用 MATLAB E
我需要将 float 转换为Q31定点,Q31表示1个符号位,0位表示整数部分,31位表示小数部分。这意味着 Q31 只能表示 [-1,0.9999] 范围内的数字。 根据定义,从浮点转换为定点时,会
我正在使用第 3 方定点 antilog() 函数来计算分贝 out_mag = 10^( in_db/20 ) 的幅度。 antilog() 采用 Q6.25 格式作为输入,并在输出时提供 Q16.
我想将一个定点数(Q31/int32 表示具有 31 个小数位的小数)除以另一个 Q31/int32。我想计算z = y/x,知道abs(x)>abs(y)。因此,z<1,因此可以表示为另一个Q31/
我是一名优秀的程序员,十分优秀!