- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试编写一个空间数据结构(例如 K-D 树
或 QuadTree
),给定一个点,它会找到 x
离它最近的点。
我上面提到的数据结构的问题是它们主要支持径向/区域搜索。因此他们将获得给定点/节点的 y
半径范围内的点。
改变这些结构来搜索我想要的内容将是低效的。我假设我需要多次重复径向搜索,从较短的径向距离开始,并不断增加它,直到我在给定点附近得到所需的 x
数量的点。当然,这违背了数据结构背后的全部目的。
几乎所有空间数据结构都在径向搜索上运行。我可以将哪些其他高效 搜索方法应用于QuadTree
,或我需要考虑的任何其他空间数据结构以实现我的意思?有什么建议吗?
最佳答案
我不确定您的假设是否正确。 Wikipedia article on kd-trees指示该结构如何用于支持查找搜索点的 x
最近邻居。是的,它本质上是重复查找最近的邻居 x
次,但我不确定您是否有权期望算法在 kd-tree 上获得更高效的性能
。
如果这对您来说还不够好,您可能需要将您的点存储在不同的数据结构中。如果 x
很小且有界,您可以将点存储在加权图中,其中边权重当然是点之间的距离。
如果 x
既不小也没有边界,您可以将空间简单分割为 k*m
均匀单元(此处为 2D,必要时膨胀为 3+D) .对于每个搜索点,直接转到包含它的单元格,找到同一单元格中的其他点。如果它们中的 x
比单元格的边界更靠近搜索点,那么这些就是您要查找的内容。如果不是,也搜索附近边界另一侧的单元格。
如果您发现自己需要同时支持径向/区域搜索和x-最近邻搜索,那么如果您必须维护 2 种数据结构,一种支持每种类型的数据结构,那还不是世界末日询问。对于许多搜索问题,有效解决方案的第一步是将数据放入正确的结构中以进行有效搜索。做出此决定取决于您尚未向我们提供的数字。
关于algorithm - 空间数据结构中的不同搜索方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11902211/
我想了解 Ruby 方法 methods() 是如何工作的。 我尝试使用“ruby 方法”在 Google 上搜索,但这不是我需要的。 我也看过 ruby-doc.org,但我没有找到这种方法。
Test 方法 对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。 object.Test(string) 参数 object 必选项。总是一个
Replace 方法 替换在正则表达式查找中找到的文本。 object.Replace(string1, string2) 参数 object 必选项。总是一个 RegExp 对象的名称。
Raise 方法 生成运行时错误 object.Raise(number, source, description, helpfile, helpcontext) 参数 object 应为
Execute 方法 对指定的字符串执行正则表达式搜索。 object.Execute(string) 参数 object 必选项。总是一个 RegExp 对象的名称。 string
Clear 方法 清除 Err 对象的所有属性设置。 object.Clear object 应为 Err 对象的名称。 说明 在错误处理后,使用 Clear 显式地清除 Err 对象。此
CopyFile 方法 将一个或多个文件从某位置复制到另一位置。 object.CopyFile source, destination[, overwrite] 参数 object 必选
Copy 方法 将指定的文件或文件夹从某位置复制到另一位置。 object.Copy destination[, overwrite] 参数 object 必选项。应为 File 或 F
Close 方法 关闭打开的 TextStream 文件。 object.Close object 应为 TextStream 对象的名称。 说明 下面例子举例说明如何使用 Close 方
BuildPath 方法 向现有路径后添加名称。 object.BuildPath(path, name) 参数 object 必选项。应为 FileSystemObject 对象的名称
GetFolder 方法 返回与指定的路径中某文件夹相应的 Folder 对象。 object.GetFolder(folderspec) 参数 object 必选项。应为 FileSy
GetFileName 方法 返回指定路径(不是指定驱动器路径部分)的最后一个文件或文件夹。 object.GetFileName(pathspec) 参数 object 必选项。应为
GetFile 方法 返回与指定路径中某文件相应的 File 对象。 object.GetFile(filespec) 参数 object 必选项。应为 FileSystemObject
GetExtensionName 方法 返回字符串,该字符串包含路径最后一个组成部分的扩展名。 object.GetExtensionName(path) 参数 object 必选项。应
GetDriveName 方法 返回包含指定路径中驱动器名的字符串。 object.GetDriveName(path) 参数 object 必选项。应为 FileSystemObjec
GetDrive 方法 返回与指定的路径中驱动器相对应的 Drive 对象。 object.GetDrive drivespec 参数 object 必选项。应为 FileSystemO
GetBaseName 方法 返回字符串,其中包含文件的基本名 (不带扩展名), 或者提供的路径说明中的文件夹。 object.GetBaseName(path) 参数 object 必
GetAbsolutePathName 方法 从提供的指定路径中返回完整且含义明确的路径。 object.GetAbsolutePathName(pathspec) 参数 object
FolderExists 方法 如果指定的文件夹存在,则返回 True;否则返回 False。 object.FolderExists(folderspec) 参数 object 必选项
FileExists 方法 如果指定的文件存在返回 True;否则返回 False。 object.FileExists(filespec) 参数 object 必选项。应为 FileS
我是一名优秀的程序员,十分优秀!