- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
假设如果所有边的权重都是正数,则可以通过对每条边取 log
然后应用 Kruskal 或 Prim 来获得最小乘积生成树。但是如果一些权重是负的,我们就不能应用这个过程。因为我们需要包括奇数个负边,并且这些边必须具有最大权重。遇到这种情况怎么办?
最佳答案
我非常怀疑您是否可以修改 Prims 算法来解决这个问题,因为负数会完全改变它。如果您设法获得负结果,则必须最大化绝对值,这意味着必须使用具有最高绝对值的边缘,因此尝试优化 Prims 算法找到的结果并采用 log(abs()) 将不起作用,除非不可能得到否定结果,否则这实际上将返回最佳解决方案。
这让问题变得更简单了,因为我们只需要寻找最好的负解,如果我们没有找到任何我们使用 Prims with log(abs())。
如果我们为每个顶点分配一个值 1,那么可以通过创建一个新顶点来合并两个顶点,该新顶点具有两个顶点的所有边(连接它们的边除外),该值是删除顶点值的乘积和边缘。
基于此我们可以开始简化,将所有节点合并为一条边。与每个合并步骤并行,删除的边必须标记为在原始图中使用,以便最终可以从标记的边重建树。
此外,我们可以合并所有只有正边或只有负边的节点,移除绝对值最高的边。合并后,新节点可以与同一节点有多个连接,您可以丢弃除具有最高绝对值的负边缘和正边缘之外的所有连接(因此最多 2 个边缘到同一节点)。顺便提一句。一旦我们有 2 条边到同一节点(遵循上述删除条件),我们就知道必须存在一个解决方案 <= 0。
如果你最终得到一个节点并且它是负的那么问题就成功解决了,如果它是正的则没有负的解决方案。如果我们有一个 0 顶点,我们可以按任何顺序合并其余节点。更有可能的是,我们最终得到一个高度连接的图,其中每个节点至少有一个负边和一个正边。如果我们有奇数个负顶点,那么我们想要合并具有偶数个负边的节点,反之亦然。
总是按绝对值最高的边合并。如果生成的顶点 <= 0 那么您找到了最佳解决方案。否则会变得复杂。您可以查看所有未使用的边,尝试添加它,查看可以删除哪些边以使其再次成为树,只查看具有不同符号的边并构建比率 abs(added_edge/removed_edge)。然后最后以最佳比例进行更改(如果找到任何符号相反的组合,否则没有负解)。但我不能 100% 确定这是否总能给出最佳结果。
关于algorithm - 具有负权重的最小产品生成树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43931668/
我有一个非常基本的 MySQL 查询,它从数据库表中读取行并将行值添加或减去定义为 $total_balance 的 PHP 字符串。 例如; $statement_details_query = m
我有 following fiddle ,请注意,如果您使输出的宽度变小,图像将被覆盖并且不会出现滚动条 - 完美。 如果我attempt the same effect on the right ,
这个正则表达式将得到 456。我的问题是为什么它不能是 1-234-56 中的 234 ? 56 是否限定 (?!\d)) 模式,因为它不是单个数字。 (?!\d)) 寻找的起始点在哪里? impor
我需要知道两个子结构之间的内存距离 (&my_type.a - &my_tape.b.c) 结果的类型是什么?我需要将它转换为 (signed int),所以显然它是别的东西。 最佳答案 根据 C11
我遇到了一个扩展异常的异常处理程序类,如下所示: public class AppFileReaderException extends Exception { //Explicit seri
如何可视化负 RGB 值? 根据 OpenCV 文档: CV_8S - 8 位有符号整数 (-128..127) 这是否意味着 -128 表示 0 而 127 表示 255? 如果是,那我们为什么需要
我这里有一段代码给我带来了麻烦: idIndex = panoBuffer.indexOf("\"photo_id\":"); System.out.println(idIndex);
我刚刚练习 Java,对此还很陌生。我只是想创建一个随机数生成器程序来跟踪玩家的获胜、失败、获胜百分比和总获胜金额。该程序的逻辑是,玩家每次 session 有 3 次机会,计算机会生成一个随机数,玩
因此,我们被要求创建一个程序,使用户能够从 1-6 个有关矩阵运算的选项中进行选择。在每个用户的输入中,我们需要检查该输入是否适合要完成的操作(程序应该接受整数或 float ,正数或负数)。如果不满
这是我期望的输出 x |x| 1.2 1.2 -2.3 2.3 3.4 3.4 但我一直收到这个: x |x| 1
假设我有这个: $date1=date_create(date('H:I', strtotime('8:00'))); $date2=date_create(date('H:I', strtotime
如何确定负 FixNum 的无符号解释? # unexpected, true (~0b01111011).to_s(2) == ("-" + (~0b01111011).abs.to_s(2)) #
这是一个用于“邀请您的 friend 加入此群组”脚本的快速 SQL 查询。 我有 2 个表:users 和 group_members。我正在尝试执行一个查询,选择我所有的 friend ——由第一
负 ASCII 值有什么意义? int a = '«'; //a = -85 but as in ASCII table '<<' should be 174 最佳答案 没有负数ASCII值。 ASC
我知道用 PHP 可以做到这一点,但是有没有办法只用 MySQL 来做到这一点? 我有这个数据库: --------------------------------------------------
我在变量中有一个时间戳 $data = (float) -2208988800; 是否可以根据这些数据创建正确的日期?date("d.M.Y", $data) 返回“07.02.2036” 最佳答案
你好我如何将括号格式的负值转换为 double 值。目前我有这个。 Payment.Text = Calc_Payment().ToString("#,##0.00;(#,##0.00)"); 将支付
这是一个小程序。这应该打印 0 或 1,还是它有未定义的行为? #include struct S0 { unsigned f1 : 1; }; struct S0 s; int main (v
运行 lgb.cv 时,我有时会从日志中看到“从分数开始训练”后的负数。想知道这个数字到底是什么意思,单位是什么?是根据参数中指定的指标吗?以下是摘录: [LightGBM] [Info] Total
我正在使用变分自动编码器类型模型,我的损失函数的一部分是均值为 0 和方差为 1 的正态分布与另一个均值和方差由我的模型预测的正态分布之间的 KL 散度。 我用以下方式定义了损失: def kl_lo
我是一名优秀的程序员,十分优秀!