找到 510 篇文章 算法

拓扑排序

Ankith Reddy
更新于 2020-06-16 14:05:13

6K+ 阅读量

有向无环图的拓扑排序是指顶点的线性排序。对于有向图的每条边 U-V,顶点 u 将在排序中出现在顶点 v 之前。众所周知,源顶点将在目标顶点之后出现,因此我们需要使用栈来存储先前的元素。完成所有节点后,我们可以简单地从栈中显示它们。输入和输出输入:0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 1 0 0 0 0 1 1 0 0 0 0 ... 阅读更多

Tarjan 算法用于强连通分量

Samual Sam
更新于 2020-06-16 14:09:17

2K+ 阅读量

Tarjan 算法用于查找有向图的强连通分量。它只需要一次 DFS 遍历即可实现此算法。使用 DFS 遍历,我们可以找到森林的 DFS 树。从 DFS 树中,可以找到强连通分量。当找到此类子树的根时,我们可以显示整个子树。该子树是一个强连通分量。输入和输出输入:图的邻接矩阵。0 0 1 1 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 输出:给定图中的强连通分量... 阅读更多

蛇梯游戏

George John
更新于 2020-06-16 14:12:48

1K+ 阅读量

我们了解著名的蛇梯游戏。在这个游戏中,棋盘上有一些房间,带有房间号。一些房间通过梯子或蛇连接。当我们得到梯子时,我们可以爬到一些房间以接近目的地,而无需按顺序移动。类似地,当我们得到一些蛇时,它会将我们送到一个较低的房间,以便从那个房间重新开始旅程。在这个问题中,我们必须找到从起点到目的地的最小掷骰次数。输入和输出输入:起始和... 阅读更多

强连通图

karthikeya Boyini
更新于 2020-06-16 14:16:40

4K+ 阅读量

如果在一个有向图中,每个顶点对之间都存在一条路径,则称该有向图是强连通的。为了解决此算法,首先使用 DFS 算法获取每个顶点的完成时间,现在找到转置图的完成时间,然后按拓扑排序对顶点进行降序排序。输入和输出输入:图的邻接矩阵。0 0 1 1 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 输出:以下是给定图中的强连通分量... 阅读更多

具有精确 k 条边的最短路径

Samual Sam
更新于 2020-06-16 12:34:11

495 阅读量

给定一个有向图,其中每对顶点之间的权重,以及两个顶点 u 和 v。我们的任务是找到从顶点 u 到顶点 v 的最短距离,且恰好有 k 条边。为了解决这个问题,我们将从顶点 u 开始,到达所有相邻的顶点,并使用 k 值为 k - 1 对相邻的顶点进行递归。输入和输出输入:图的成本矩阵。0 10 3 2 ∞ 0 ∞ 7 ∞ ∞ 0 6 ∞ ∞ ∞ 0 输出:最短... 阅读更多

最大二分匹配

karthikeya Boyini
更新于 2020-06-16 12:37:58

8K+ 阅读量

二分匹配是指以这样一种方式选择图中的一组边,即该集中没有两条边共享端点。最大匹配是指匹配最多的边数。当找到最大匹配时,我们不能再添加另一条边。如果向最大匹配图中添加一条边,它将不再是匹配。对于二分图,可能存在多个最大匹配。输入和输出输入:邻接矩阵。0 1 1 0 0 0 1 0 0 1 0 0 0 0 1 0 0 ... 阅读更多

有向无环图中的最短路径

Ankith Reddy
更新于 2020-06-16 14:20:59

1K+ 阅读量

给定一个加权有向无环图。还提供了另一个源顶点。现在我们必须找到从起始节点到图中所有其他顶点的最短距离。为了检测较小的距离,我们可以使用其他算法,例如 Bellman-Ford 用于带负权重的图,对于正权重,Dijkstra 算法也很有用。这里对于有向无环图,我们将使用拓扑排序技术来降低复杂度。输入和输出输入:图的成本矩阵。0 5 3 -∞ -∞ -∞ -∞ 0 2 6 -∞ -∞ -∞ -∞ 0 7 4 2 -∞ ... 阅读更多

如何判断图是否是二分图?

Arjun Thakur
更新于 2020-06-16 12:41:36

4K+ 阅读量

如果图的顶点可以分成两个独立的集合,使得图中的每条边都从第一个集合开始并在第二个集合结束,或者从第二个集合开始,连接到第一个集合,换句话说,我们可以说在同一个集合中找不到任何边,则称该图是二分图。可以使用顶点着色来检查二分图。当一个顶点在同一个集合中时,它具有相同的颜色,对于另一个集合,颜色将发生变化。输入和输出输入:... 阅读更多

有向无环图中的最长路径

Samual Sam
更新于 2020-06-16 12:46:03

1K+ 阅读量

给定一个加权有向无环图。还提供了另一个源顶点。现在我们必须找到从起始节点到图中所有其他顶点的最长距离。我们需要按拓扑排序技术对节点进行排序,并将拓扑排序后的结果存储到堆栈中。之后反复从堆栈中弹出并尝试为每个顶点找到最长距离。输入和输出输入:图的成本矩阵。0 5 3 -∞ -∞ -∞ -∞ 0 2 6 -∞ -∞ -∞ -∞ 0 7 4 2 -∞ -∞ ... 阅读更多

图着色

karthikeya Boyini
更新于 2020-06-16 12:53:49

6K+ 阅读量

图着色问题是图标记的一个特例。在这个问题中,每个节点都用一些颜色着色。但是着色有一些约束。我们不能对任何相邻的顶点使用相同的颜色。为了解决这个问题,我们需要使用贪婪算法,但它不能保证使用最少的颜色。输入和输出输入:图的邻接矩阵。0 0 1 0 1 0 0 1 1 1 1 1 0 1 0 0 1 1 0 1 1 1 0 1 0 输出:节点:0,分配的颜色:0 节点:1,分配的颜色:0 ... 阅读更多

广告