- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有兴趣实现和研究 Kirkpatrick–Seidel algorithm .这是找到一组点的凸包的分而治之的方法。我只关心二维情况。
我发现了一份关于这个问题的有趣讲义 here :
算法的大致步骤如下:
INPUT: A set P of points on the plane.
OUTPUT: The set of points that define the convex hull.
1. Calculate median x-coordinate M of P.
2. Find the bridge segment that crosses the line x = M using the
Prune and Search Technique.
3. Trim the set based on this segment
4. Split P to sets PL, PR and recursively apply the above steps to find
the remaining segments
5. The above steps must be run twice, once for the upper hall and once
for the lower hall. Once you find both, you have the convex hull.
(1) 可以在 O(N) 中找到。这非常简单,尤其是在 C++ 中,您可以只使用 nth_element
带有指定的比较器
(3) 也可以在 O(N) 中找到。如果您找到的线段由点定义 p1
和 p2
那么你只需要忽略每个点 p
其中 p1.x <= p.x <= p2.x
(4) 只是(3)
的直接结果(5) 对您刚刚找到的两个子集进行两次递归调用
为了实现O(nlogn)
这种分而治之算法的复杂性。我们还需要步骤(2) 来获取O(n)
.
根据讲义,这一步可以用线性规划来解决,因为我们是在平面上工作,所以可以达到线性时间。
现在,讲义将更详细地解释 (2) 部分,这是步骤。
我理解除 (3) 和 (4) 之外的所有步骤。
(3)。什么是 b
?我想没关系。既然你已经找到斜坡 m
然后继续寻找集合 P 的支撑线。B 是您正在寻找的东西。
(4)。集合P的支撑线是什么,如何高效找到它?
最佳答案
给定一个斜率和一个点,存在一条通过该点的斜率的唯一直线。设斜率为 m,点为 (px, py)。然后求解方程中的b py = m px + b(即b = py - m px);这条线有等式 y = m x + b。您在步骤 (3) 和 (4) 中应该做的是为每个点计算 b 并将 p_t 设为具有最大 b 的点(通过最大 x 坐标打破平局)。这条线是凸包的支撑线,因为它包含一个顶点,并且所有顶点(不正确地)都在一侧(在本例中,不在它上面)。
附言如果您因为 O(n log h) 运行时间而感兴趣,那么请不要抱太大希望;常数因子看起来很糟糕。
关于c++ - 婚前征服凸包算法的实现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26195947/
通过终端,您可以使用命令 - “SetFile -a B 文件名” 以编程方式,我认为我应该通过[[NSFileManager defaultManager] createDirectoryAtPat
嗨,正在尝试书中的一些示例:Practical Graph mining with R对于子图挖掘: library(subgraphMining) library(igraph) graph1 =
代码中的相同问题: class Foo { int getIntProperty () { ... } CustomObject getObjectProperty () { ... }
所以这可能是一个愚蠢的问题,但它已经困扰我一段时间了。 使用 React,我创建了两个组件(Buttons.js 和 Message.js),每个组件都有一个导出。但是,现在我希望将这两个组件用作 n
从今天早上开始,我发现我无法再从某个范围安装任何 NPM 包(或任何具有依赖项的包)。例如,如果我输入 npm i webpack 我会收到以下错误... npm ERR! code E401 npm
我在这里搜索过,Angular 2, @ngtools/webpack, AOT ,但对我不起作用。我运行了 npm install 命令。我正在做的是创建一个新的 Angular 2 项目。当我运行
情况: 我有一个 Swift 包,将其命名为 lib。 lib 位于其自己的存储库中。在lib的仓库中,有一堆本地包;也就是说,这些包是在 lib 中定义的,使用本地路径依赖格式 .package(p
我想在工作中学习和使用nodejs,但是在使用 de npm 命令安装模块/包时遇到网络问题。我是否可以使用我的家用计算机构建完整的 Node js 包,然后将其安装在另一台计算机(我的工作场所计算机
我需要将一些 .tar.bz2 格式的非 Python 包转换为 Anaconda/miniConda .egg 文件并安装它们。为此,我需要一个适用于 Windows 的 bld.bat 文件。互联
我需要共享库文件 libthrift-0.9.3.so 作为其他包的依赖项。我在构建 thrift-0.9.3 包时看到编译问题(我确实从 https://thrift.apache.org/down
我尝试在 R 版本 3.5.0 中安装“arcgisbinding”包。但是我失败了,得到以下错误和警告。 Installing package into ‘C:/Users/Lenovo/Docum
我尝试在 R 版本 3.5.0 中安装“arcgisbinding”包。但是我失败了,得到以下错误和警告。 Installing package into ‘C:/Users/Lenovo/Docum
我试图在 flutter 中测试这个应用程序,但我无法运行该应用程序,因为出现此错误“名称‘Page’在库‘package:burn_off/widgets/page.dart’和‘package’中
试图理解和学习如何编写包...用我一直使用的东西进行测试,记录... 您能帮我理解为什么“日志”变量不起作用...并且屏幕上没有日志记录吗? 谢谢! 主要文件: #!/opt/local/bin/py
我尝试运行此使用 Google 云的代码。 import signal import sys from google.cloud import language, exceptions # creat
我想知道是否有人找到了一个很好的 R 包来分析眼动追踪数据? 我遇到了 eyetrackR,但据我所知,没有可用的英文支持文档: http://read.psych.uni-potsdam.de/pm
我正在 R 上制作一个包。我有两个函数共享一个变量(全局)。 如何将其导入到包中? 例如, m<-0 f<-function() { m <- m+1 } g<-function() { m <- m
我用 C 为 Lua 编写了很多模块。每个模块都包含一个 Lua 用户数据类型,我像这样加载和使用它们: A = require("A") B = require("B") a = A.new(3,{
我正在尝试在 R 中的 Ubuntu 上安装 xlsx 包,以便使用允许在 R 中插入链接然后将它们导出到 Excel 的功能。 话虽如此,我根本无法安装该软件包。 显然它必须与 rJava 一起使用
我想在 Haskell 中做一些蒙特卡洛分析。我希望能够编写这样的代码: do n <- poisson lambda xs <- replicateM n $ normal mu sigma
我是一名优秀的程序员,十分优秀!