- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
假设我们 E 是一个 nxn 矩阵,其中 E[i,j] 表示从货币 i 到货币 j 的汇率。 (1个货币i可以得到多少货币j)。 (注意,E[i,j]*E[j,i] 不一定为 1)。
想出一个算法来找到一个正循环(如果存在的话),其中正循环定义为:如果你从第 i 种货币开始,你可以继续交换货币,这样最终你可以回来并拥有超过1 种货币 i.
这个问题我想了好久,但好像想不通。我唯一能想到的就是将所有内容表示为一个有向图,其中矩阵 E 作为邻接矩阵,其中 log(E[i,j]) 是顶点 i 和 j 之间的权重。然后你会寻找一个带有负面路径或其他东西的循环。这有意义吗?有没有更有效/更简单的方法来思考这个问题?
最佳答案
首先,记录汇率(这不是绝对必要的,但这意味着我们可以像往常一样谈论“增加长度”)。然后您可以对 Floyd-Warshall algorithm 进行轻微修改。找到每对顶点之间至少与最长的顶点一样长的可能不简单路径的长度(即可能在不同位置多次循环自身的路径)它们之间的简单路径。唯一需要的改变是翻转比较的符号,这样我们总是寻找最长路径(更多细节见下文)。最后,您可以查看所有 O(n^2) 对顶点 u 和 v,取每个方向(从 u 到 v,以及从 v 到 u)的 2 条路径的长度之和。如果其中任何一个大于 0,那么您已经找到了一个(可能是非简单的)循环,其总汇率 > 1。总体而言,算法的 FW 部分占主导地位,使得这个 O(n^3) -时间。
一般来说,尝试使用像 FW 这样的算法来寻找最大权重路径的问题在于,它可能会将共享一个或多个顶点的 2 个子路径连接在一起,而我们通常不会这样做想要这个。 (在没有负环的图中寻找最小长度路径时永远不会发生这种情况,因为这样的路径必然包含可以删除的正权重环,所以它永远不会被选为最优。)如果我们正在寻找最大-权重简单循环,这将是一个问题;在那种情况下,为了解决这个问题,我们需要为顶点的每个子集考虑一个单独的子问题,这会将时间和空间复杂度推高至 O(2^n)。然而,幸运的是,我们只关心找到一些正权重循环,并且很容易看出如果 FW 找到的路径碰巧多次使用某个顶点,那么它必须包含一个非负权重循环——它可以被删除(如果它的权重为 0),或者(如果它的权重 > 0)本身就是一个“正确答案”!
如果您关心找到一个简单的循环,这很容易在最后一步中完成,该步骤与 FW 报告的路径长度成线性关系(顺便说一句,可能是 O(2^|V|) -- 如果所有路径都具有正长度,那么所有“最佳”长度将随着每次最外层迭代而加倍——但这不太可能发生在这里)。取 FW 结果隐含的最优路径对(每条路径可以用通常的方式计算,通过为每个顶点对 (i, j) 保留一个 k 的“最优前驱”值表),然后简单地沿着它走,分配给您访问的每个顶点到目前为止的运行总长度,直到您遇到您已经访问过的顶点。此时,要么currentTotal - totalAtAlreadyVisitedVertex > 0
,在这种情况下你刚刚找到的循环具有正权重并且你已经完成,或者这个差异为0,在这种情况下你可以删除对应的边从路径到这个循环并照常继续。
关于algorithm - 寻找 "positive cycle",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33418941/
我刚开始使用 html5 和 css,我对使用 css position 有点困惑。 我可以从堆栈溢出中找到这些链接, Difference between relative and absolute
我想知道是否有一种方法可以获得相对定位的元素的“绝对位置”。我想不出任何方法,但也许有人想出了一个方法...... 最佳答案 我不确定“绝对位置”是什么意思,但您可以使用 el.getBounding
基本上我的 HTML(使用 Bootstrap 类)中有一个页面,其中包含使用 thumbnail 和 caption 类展示的产品。在产品图片上方有一个 ON SELL(圆形红色标签)。我给这个红色
当我使用 BaseAdapter 的 ListView 离开屏幕时,每一行不再保持连续的位置。除了这个我不知道还能怎么解释。 如果我的 BA/LV 在屏幕上显示 4 个项目,并且我添加了一个显示每一行
此 HTML 无法在 IE8 中正确呈现。它适用于 Firefox、Opera、IE7、IE9 和 IE10。 (当然,它在 IE6 中也不起作用,因为它涉及固定位置的元素。) 实际上它在 Chrom
我正在使用Position Absolute的表单验证引擎。 我有一个特定的验证案例,希望可以为我解决。我需要能够根据另一个字段的值来使一个字段成为必需。 例如: If country.dropdow
我看过很多帖子,人们希望将相机位置调整到屏幕位置。我的问题是如何做相反的事情。 我目前想要实现的是将“门”位置设置为屏幕的百分比,此计算已准备就绪,并且我确实有最终屏幕的 X、Y (px) 位置。相机
谁能解释一下使用 position:relative、position:absolute 和 float 对正常文档流及其子项的影响的区别? 例如当我有三个元素 A、B、C 时,其中 A 是包含 B
我有以下代码: .tabs{ position: fixed; top:110px; left:0px; width:40px; z-inde
我不知道如何表达这个问题。 所以这是一个例子。 图层上的动画滑入 View ,然后稍微弹回。 十分简单。 位置关键帧看起来像这样: 关键帧 0:(-100,200) 关键帧 10:(100,200)
我是 XSLT 的新手,我正在使用 w3schools 的“自己尝试”页面进行一些测试。我正在使用以下演示: http://www.w3schools.com/xsl/tryxslt.asp?xmlf
我试图让一个对象 1 (SKSpriteNode) 在某个高度(y 坐标)处创建另一个对象 (object2)。我已经得到了我需要的所有代码,除了我不知道如何正确编写: object1.positio
.special p { display:none; } .special:hover p { display:block; } Things
当将一个绝对定位元素放置在一个位置固定包装器中时,在一个位置相对包装器中,绝对元素位置不应该相对于相对 parent 而不是固定 parent ? Content
我有一个 iframe,它在应用 css 后显示谷歌地图 position: relative; top: 48px; left: -233px; 但是当我向下滚动时,它刚好出现在显示 khaleej
我在一个网站上工作,有一个带有 position:relative 的父元素,它有一个带有 position:absolute 的子元素。令我感到奇怪的是,对于我提到的位置,子元素似乎仍然可以识别它们
我有一个 main 元素,我已将其设置为 position: relative。这包含两个 div,然后我在其上应用 position: absolute。然后,这会导致夹在 main 元素中间的页眉
HTML 代码由一个 div 组成,它具有两种类型的类:“隐藏”和“保留”。 Lorem ipsum dolor sit amet, consectetur adipis
我必须开发一个生成表格(有点……)的软件,并且必须提供对元素位置的完全控制。 到目前为止,我们有这样的构造: 还有一些javascript代码来放置#a , #b和 #c #co
我尝试将 z-index 设置为 body 下的某些位置为 fixed 的元素 示例如下: HTML menu content ....
我是一名优秀的程序员,十分优秀!