首页 > 后端开发 > php教程 > 。冗余连接

。冗余连接

Barbara Streisand
发布: 2025-01-30 08:04:39
原创
650 人浏览过

684。冗余连接

难度:中等

>>主题:深度优先搜索,广度优先搜索,联合查找,图形

在这个问题中,一棵树是连接且没有循环的无向图>您获得了一个图形,该图是从1到n标记的n个节点开始的树,并增加了一个边缘。添加的边缘具有从1到n选择的两个不同的

的顶点,并且不是已经存在的边缘。该图表示为长度为n的数组边缘,其中边缘[i] = [ai ,bi]表明节点ai 返回可以删除的边缘,以便结果图是N节点的树。如果有多个答案,请返回在输入

>

>示例1:

>输入: edges = [[1,2],[1,3],[2,3]]

>输出:。冗余连接 [2,3]

  • >>示例2:
>输入:

edges = [[1,2],[2,3],[3,4],[1,4],[1,5]] >输出:

[1,4]

。冗余连接

    >约束:
  • >
  • n == edge.length
  • 3< = n< = 1000
  • edges [i] .length == 2

1< = a i< bi

< = edges.length
  • a
  • i
  • != b
  • i
  • >
  • 没有重复的边缘。 给定的图是连接的。
  • 解决方案: 冗余连接
  • 问题要求我们确定图形中的边缘,可以将图形转换为有效的树。树是连接和无环的无向图。给我们一个图形,该图是从树开始的,但通过添加一个额外的边缘进行了修改。我们的目标是找到并返回这个额外的优势。
  • >
  • 关键点
该图是

未取向

删除冗余边缘后所得的图形必须没有周期。 答案应返回输入中出现的最后一个

的边缘,如果有多个有效的解决方案。

由于单个额外的边缘,该图最多可以具有一个周期。

    方法
  1. 该方法涉及使用>深度优先搜索(DFS)来检测周期:
  2. >邻接列表表示
    • >使用邻接列表来表示图形。该结构适合有效地执行DF。
  3. 通过DFS
  4. 循环检测:> 在将边缘添加到图表之前,请使用DFS检查边缘两个顶点之间是否已经有一个路径。如果有的话,添加此边缘将形成一个周期。

    返回边缘
  5. 如果检测到一个周期,请返回当前边缘作为冗余连接。

    • 计划
  6. 解析输入边缘。

维护一个邻接列表以动态跟踪图形的连接。

对于每个边缘:
  1. 使用递归DFS函数检查两个顶点之间的路径是否存在。
  2. 如果存在路径,请返回边缘作为冗余连接。
  3. 否则,将边缘添加到邻接列表中。
    • 如果找不到冗余边缘,则返回空结果(尽管这不会按照问题的限制发生)。
    • >让我们在PHP中实现此解决方案: 684。冗余连接
  4. 解释:

dfs实现

<?php /**
 * @param Integer[][] $edges
 * @return Integer[]
 */
function findRedundantConnection($edges) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * Helper function to perform DFS and check connectivity
 *
 * @param $src
 * @param $target
 * @param $visited
 * @param $adjList
 * @return bool
 */
private function isConnected($src, $target, &$visited, &$adjList) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example usage:
$edges1 = [[1,2],[1,3],[2,3]];
$edges2 = [[1,2],[2,3],[3,4],[1,4],[1,5]];

print_r(findRedundantConnection($edges1)) . "\n"; // Output: [2,3]
print_r(findRedundantConnection($edges2)) . "\n"; // Output: [1,4]
?>
登录后复制

从一个节点开始,然后递归访问其邻居。

使用访问的数组避免重新访问节点。
    如果在遍历期间达到目标节点,则存在一条路径。
  1. edge Addad
    • 如果在边缘的顶点之间不存在路径,请将边缘添加到邻接列表中,然后继续进行下一个边缘。
  2. 冗余边缘
  3. 如果已经存在路径,请在形成周期时返回当前边缘。

    • 示例演练
  4. 示例1:
  5. >输入:edges = [[1,2],[1,3],[2,3]]

      步骤

  6. >将邻接列表初始化为[]。

处理边缘:

添加[1,2]→图:{1:[2],2:[1]}

添加[1,3]→图:{1:[2,3],2:[1],3:[1]} 检查[2,3]:DFS找到路径→返回[2,3]。

>输出
    :[2,3]
  1. 示例2:
    • > input
    • :edges = [[1,2],[2,3],[3,4],[1,4],[1,5]]
    • 步骤
    >将邻接列表初始化为[]。
处理边缘:

添加[1,2]→图:{1:[2],2:[1]}

添加[2,3]→图:{1:[2],2:[1,3],3:[2]}

添加[3,4]→图:{1:[2],2:[1,3],3:[2,4],4:[3]}

检查[1,4]:DFS找到路径→返回[1,4]。

输出

:[1,4] 时间复杂性
    • dfs traversal
      • 对于每个边缘,我们执行一个DFS来检查连接。>
      • 最差的情况:
      • o(v e),其中 vv 是顶点的数量,> e> e
      • 是边缘的数量。
  • 总复杂度

    • 由于我们为每个边缘执行DFS,因此总体复杂性为o(e×(v e))
  • 空间复杂度

    • 邻接列表:o(v e)
    • 访问阵列:o(v)
    • o(v e)
  • 输出示例

    示例1:

    >输入:[[[1,2],[1,3],[2,3]] >

    >输出:[2,3]

    示例2:

    > input :[[[1,2],[2,3],[3,4],[1,4],[1,5]] >输出
    :[1,4] 可以使用基于dfs的方法来有效解决该问题以检测周期。此方法动态构建图形并在每个步骤中检查冗余边缘。该解决方案通过遵守问题约束并输出形成周期并发生在输入中的边缘的边缘来确保正确性。>

    联系链接

    如果您发现此系列有帮助,请考虑在Github上给出 reposority >在您喜欢的社交网络上分享帖子?您的支持对我来说意义重大!

    > 如果您想要这样的更多有用的内容,请随时关注我:>

    LinkedIn

    github

    以上是。冗余连接的详细内容。更多信息请关注PHP中文网其他相关文章!

    本站声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    作者最新文章
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板