- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个带有彩色加权边的有向图。有2种颜色。每条边只能有一种颜色。我想找到颜色变化有限的最短路径。从一个顶点开始,最多可以有 2 strip 2 种不同颜色的边和 2 strip 2 种不同颜色的边。
例如在这张图中:
最多 3 种颜色变化的最短路径将为 9
最大 0
颜色变化最短路径为 6+1+4=11
,等等。
我的解决方案是递归访问所有可能的路径,如果递归找到更好的路径则交换,这使得这个问题呈指数增长。
这个问题有非指数解吗?
最佳答案
这可以通过在适当构造的图上运行 Dijkstra 算法在时间 O(nm + n2 log n) 中解决。
为了激发我们前进的直觉,让我们现在假设最佳路径最多改变一种颜色,并从沿着红色边缘开始。因此,该路径要么不遵循蓝色边缘,在这种情况下我们只遵循红色边缘,要么遵循一定数量的红色边缘,然后是一定数量的蓝色边缘。
想想如果按如下方式变换 G 会发生什么:
您可以将此图视为 G 的两个副本相互堆叠,并对边缘进行了一些调整。具体来说,在 G0 内部运行的边都是红色的,蓝色的边带你到 G1。那么 G1 中就没有红边了。
想想这个图中的路径是什么样的。如果你只停留在 G0 中,它只包含红色边缘。如果您从 G0 开始并在 G1 结束,那么路径开始时遵循一定数量的红色边缘,然后是至少一个蓝色边缘,然后是更多数量的蓝色边缘。因此,此图中的任何路径都将只涉及一种颜色变化。
您可以使用此图找到从节点 u 到节点 v 的最短路径,该路径最多改变一种颜色。首先从 u 开始运行 Dijkstra 算法,然后查看 v0 和 v1 的距离。到 v0 的距离是到 v0 且颜色不变的最短路径的长度。到 v1 的距离是到 v1 的最短路径的长度,该路径最多使一种颜色发生变化。这两个距离中较短的一个就是从 u 到 v 的最短路径的长度,该路径最多使一种颜色发生变化。
我们可以扩展这个技巧以适用于任意数量的步骤 k,如下所示。创建 G 的 k 个副本,称为 G0、G1、G2、...、G(k-1)。假设路径以红色边缘开始,我们可以按如下方式更改图形。使 G0 中的所有蓝色边改为从 G0 运行到 G1。然后,使G1中的所有红色边都从G1到G2。然后,使 G2 中的所有蓝色边从 G2 延伸到 G3,等等。最后,删除 G(k-1) 中所有不是通向 G(k-1) 的颜色的边。该图保持与以前相同的属性——从节点 u0 到节点 v_r 的任何路径都表示从 u 到 v 的路径恰好使 r 颜色发生变化,假设第一条边是红色。通过查看到 v_0、v_1、...、v_(k-1) 的路径的最低成本,可以找到最多进行 r 次颜色变化的最佳路径。
到目前为止,这种方法假设第一步是红色的,但我们不能保证情况就是这样。但这没关系 - 我们可以在假设第一步为红色和假设第一步为蓝色的情况下运行此算法,并在两个选项中取其最佳。
那么这个到底有多贵呢?好吧,如果我们最多得到 k 种颜色变化,我们构造的图将总共有 O(nk) 个节点和 O(mk) 条边,因此构造它需要时间 O(k(m + n))。在图中运行 Dijkstra 以找到到所有目标节点的最短路径然后需要时间 O(mk + nk log nk),因此总运行时间为 O(mk + nk log nk)。
我们实际上可以将其上限设置为 O(mn + n2 log n),原因如下:由于所有边的权重都严格为正,我们知道任何路径都不能进行超过 n - 1 次的颜色更改。如果一条路径有,它至少有 n 条边,所以它会有一个环。该循环具有严格的正成本,因此我们可以通过消除循环来提高成本。因此,如果 k ≥ n,我们可以将 k 限制在 n。将 k = n 代入上述表达式得到 O(mn + n2 log n) 的渐近运行时间。
希望这对您有所帮助!
关于algorithm - 带彩色边的图 : shortest paths with at most k color changes?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24189897/
这是我的作业 What does echo PATH $PATH \$PATH do? 我不知道它是如何工作的。 echo PATH打印“路径” $PATH创建一个“PATH”变量......也许?
我想弄清楚两者之间的区别 路径=路径+[节点1] 路径+=[节点1] path.append(node1) 我得到的是 path = path + [node1] 的正确路径,但不是其他两个。 def
我使用 Robot 框架在 Ride 中创建了一个测试用例。运行时出现错误。 我更新了python的路径。我更新了库和 Ride。我换了文件夹还是不行 *** Settings *** Documen
我尝试使用额外的功能自定义 pathlib.Path()。特别是,我真的很喜欢使用上下文管理器作为移入和移出目录的方法。我一直在使用它,但我似乎在让 Path() 与自定义上下文管理器一起工作时遇到错
编辑:基于 Ulf Rompe 的评论,重要的是使用“1”而不是“0”,否则您将破坏 sys.path . 我已经做 python 很长一段时间了(一年多),我总是很困惑为什么人们建议你使用 sys.
我有兴趣这样做的原因是因为我的路径中有一部分将保持不变,但我希望将其与其所有父部分一起删除。 所以如果我们说, some/unknown/path/foo/bar/baz 我想回去 bar/baz 但
在几个 SO 的问题中,有这些行可以访问代码的父目录,例如os.path.join(os.path.dirname(__file__)) returns nothing和 os.path.join(o
我已经在我的 Linux 中安装了 anaconda 来导入 python 包。 安装 anaconda 后,我无法在 python 中使用 anaconda,经过一番搜索后我发现输入此命令我能够使用
哪个更好用,为什么?我的意思是这两个命令在哪些方面不同以及如何不同?性能、可读性…… new FileInfo(path).Name 或 Path.GetFileName(path) 最佳答案 因为您
这不适用于某些设备。 在三星设备中,他们不允许使用下载管理器下载文件。 我已经在 list 中定义了权限并获得了运行时权限。 DownloadManager downloadManager = (Do
我想知道在这个例子中使用 Paths.get() 和 Path.resolve 有什么区别: public static void main(String[] args) { Path p1
目前我正在开发一个转换由 Inkscape 创建的 svg-paths 的应用程序。现在我不清楚关于绝对和相对路径组合的路径规范。规范是否说明了同时包含相对和绝对坐标的路径定义? 特别是关于绝对贝塞尔
我正在编写脚本,我需要在用户的 $PATH 上查找命令并获取该命令的完整路径。问题是我不知道用户的登录 shell 是什么,或者他们的 do 文件中可能有什么奇怪的东西。我将 bourne shell
Metalsmith 的文档对 path() 函数没有太多解释:#path(paths...): Resolve any amount of paths... relative to the work
我知道我可以通过 regedit 更改我的 wine PATH,但实际上我只需要为一次运行更改 PATH。 例如,我的软件名为frontend.exe,这取决于example/mylib.dll,我需
因此,绝对路径是一种到达某个文件或位置的方法,描述了它的完整路径、完整路径,并且它依赖于操作系统(Windows 和 Linux 的绝对路径,例如,不同)。另一方面,相对路径是从当前位置 ..(两个点
我对编程有点陌生(不是真的,但我仍在学习 - 我们不是吗?)。虽然我了解 Java 和 Python,并且了解 C、C++、JS、C#、HTML、CSS 等(并且我可以在终端中很好地导航),但我不熟悉
我对编程有点陌生(不是真的,但我仍在学习 - 我们不是吗?)。虽然我了解 Java 和 Python,并且了解 C、C++、JS、C#、HTML、CSS 等(并且我可以在终端中很好地导航),但我不熟悉
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
使用环境变量(如 PATH)作为 $PATH 或 ${PATH} 有什么区别? 最佳答案 在大多数情况下没有区别。唯一重要的是你是否想在扩展后包含尾随文本。例如,假设您的 PATH 包含字符串 FOO
我是一名优秀的程序员,十分优秀!