- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以我在尝试实现一个功能时遇到了这个问题:
假设我有一个随机的、无向的节点图,其中一些节点相互连接。
让我们沿着某个路径将可以从彼此到达的每一组节点称为一个集合。
现在,假设图只包含一个这样的集合(即,每个节点都可以从其他节点访问)。
如果我取一个随机节点a并将其从集合中移除,我需要快速有效地确定哪些集合仍然存在如果a是集合中的一个切点,则移除它应将集合拆分为两个或多个较小的集合。我只需要一个有效的方法来做两件事:
从集合中移除并确定剩余集合,以及
添加一个新节点b,其中有任意数量的新边将其连接到其他节点。
我需要能够适度快速地执行这两个操作实际上,我在寻找一个o(log n)或o(1)的解决方案。不接受O(N)解,因为此图可能很大。我并不特别关心内存开销有谁能给我指出在这里使用哪种数据结构/算法的正确方向吗?我已经考虑过像Union Find和Djikstra这样的东西,但它们不适合我的需要。我不想每次添加或删除节点时都对整个图运行完全连接检查。
最佳答案
有一个非常好的paper by Henzinger and King。我想它能直接回答你的问题。
该方法已经删除了一个边(删除一个顶点等于删除所有对它的边缘的删除)和O(log(n)/LOGLOG(n))每个查询的最坏情况复杂度(在相同的连接组件中是V和U)的摊销O(log ^ 3(n))复杂度。
此外,此问题有许多变体,例如,如果只允许删除,则可以更快地执行此操作。
关于algorithm - 在删除连接子图的节点后确定剩余的子图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17138086/
我正在运行一个带有 while 约束的 SQL 查询,其中包含一些“id”。例如: SELECT table.id FROM TableOne table WHERE table.id IN (1,
我正在寻找在替换其中一个元素后打印元素列表的最正确方法。我可以按如下方式做,但显然很困惑。 #!/usr/bin/python import sys file = open(sys.argv[1])
这个问题在这里已经有了答案: How wide is the default `` margin? (4 个答案) How do I remove the top margin in a web
当我尝试使用命令安装 rvm 时::(I am Using UBUNTU 12.04 LTS) curl -L https://get.rvm.io | bash -s 当我尝试与简单用户相同的命令时
我使用 GOPro 工作人员 6 个月前发送给我的命令,通过终端(在 Gopro 网络上)使用 Gopro Hero3 拍摄照片/视频。有效。但是,在过去的一个月里,我一直在尝试再次执行此操作,并且不
尽管知道我不应该关闭应用程序按钮,但我仍然这样做。完成所有 Activity 后,我调用 finish() 方法,它们调用析构函数和所有内容。用户的行为也是正确的。但我想知道为什么还有 5 个打开的线
当我在 Rest Controller 中的类级别启用 @Validated spring 注释时,会生成 2 个验证上下文(每个验证上下文都有不同的前缀)。 @Validated 注释是必需的,因为
在旧的 API 中,剩余的允许容量显然作为 X-Ratelimit-Remaining 返回HTTP header 。 然而,current version's documentation对此一无所获
我一直在使用 Service Fabric 一段时间,成功构建、部署和测试了多个服务,但我刚刚完成构建的服务在部署时失败(请参阅下面的错误)。在诊断中,我尝试使用 VS 模板(没有代码更改)创建和部署
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Progress unit in ProgressDialog 如何覆盖进度条进度消息,即 61/100 到
我正在用 Objective-C (Cocoa) 编写命令行实用程序的前端。我需要解析输出以检查不同类型的消息。有两种基本类型;信息消息和下载状态消息。信息消息始终以以下内容之一开头:INFO:、WA
我是一名优秀的程序员,十分优秀!