algorithm - BFS和DFS的目的是什么?

标签 algorithm graph depth-first-search breadth-first-search

我了解了这些算法的工作原理,但它们有什么用?

我们是否将它们用于:

  • 在图中找到某个节点或
  • 寻找最短路径或
  • 找出图中的环

?

他们都只是访问所有节点并将它们标记为已访问,我不认为这样做有什么意义。

我有点迷失在这里我正在学习的东西。

最佳答案

BFS 和 DFS 是可用于各种不同目的的图搜索算法。

这两种搜索技术的一个常见应用是识别从给定起始节点可达的所有节点。例如,假设您有一组计算机,每台计算机都与少数其他计算机联网。通过从给定节点运行 BFS 或 DFS,您将发现原始计算机能够直接或间接与之通信的网络中的所有其他计算机。这些是返回标记的计算机。

BFS 具体可用于寻找未加权图中两个节点之间的最短路径。例如,假设您要将数据包从网络中的一台计算机发送到另一台计算机,并且这些计算机之间没有直接连接。您应该沿着什么路线发送数据包以使其尽快到达目的地?如果您运行 BFS 并在每次迭代中让每个节点存储一个指向其“父”节点的指针,您最终将找到从起始节点到图中每个其他节点的路由,从而最大限度地减少必须遍历的链接数到达目标计算机。

DFS 通常用作更复杂算法中的子例程。例如,Tarjan 用于计算强连接组件的算法基于深度优先搜索。许多优化编译器技术在适当构造的图形上运行 DFS,以确定应用特定操作系列的顺序。深度优先搜索也可用于迷宫生成:通过获取节点网格并将每个节点与其邻居链接,您​​可以构建表示网格的图形。对该图运行随机深度优先搜索,然后生成一个只有一个解决方案的迷宫。

这绝不是一个详尽的列表。这些算法有各种各样的应用,当你开始探索更高级的算法时,你会经常发现自己依赖 DFS 和 BFS 作为构建 block 。它类似于排序 - 排序本身并不是那么有趣,但能够对值列表进行排序作为更复杂算法中的子例程非常有用。

希望这对您有所帮助!

关于algorithm - BFS和DFS的目的是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14720691/

相关文章:

java - 目录树的递归N路合并/差异算法?

algorithm - 从最优子结构到实际算法

graph - 如何合并图中的节点?

java - 用于查找最短路径的递归 DFS 模板

algorithm - 回归目标导向行动计划

recursion - CLISP dfs 获取程序堆栈溢出

algorithm - 使用rdiff/bsdiff以最佳时间/存储/加载方式从文件的原始版本(v0.1)转到新版本(v0.2)

java - 没有正则表达式的单词模式

javascript - 从嵌套结构递归映射 3d.js 图形节点和链接

ios - 如何在 iOS 中创建流体图形动画