我正在使用邻接矩阵而不是边列表来编码 geeksforgeeks 拓扑排序实现。我的代码结构与 C++ 示例类似,但无法让我的代码访问和打印所有节点。我知道我必须从入度为 0 的顶点开始,但顶点 4 或 5(入度为 0)都不适用于我的代码。我正在使用的示例实现和图示图可以在这里找到 https://www.geeksforgeeks.org/topological-sorting/ 从顶点 5 开始时的预期输出是 542310,但我的代码输出 52310。预期输出当从 4 开始时是 452310 但我的代码输出 410.
#include <iostream>
#include <vector>
#include <stack>
using namespace std;
vector<int> topoSort(int A[6][6], int start);
void topoSortHelper(int A[6][6], int start, vector<bool>& visited, stack<int>& s);
vector<int> topoSort(int A[6][6], int start)
{
vector<bool> visited(6,false);
stack<int> s;
vector<int> result;
for(int i = 0; i < 6; i++)
{
visited[i] = false;
}
visited[start] = true;
topoSortHelper(A, start, visited, s);
while(!s.empty())
{
cout << s.top();
s.pop();
}
return result;
}
void topoSortHelper(int A[6][6], int start, vector<bool>& visited, stack<int>& s)
{
for(int i = 0; i < 6; i++)
{
if(A[start][i] == 1 && visited[i] == false)
{
visited[i] = true;
topoSortHelper(A, i, visited, s);
}
}
s.push(start);
}
int main()
{
int A[6][6] =
{
{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},
{1, 0, 1, 0, 0, 0}
};
vector<int> result = topoSort(A, 5);
for(auto i: result)
{
cout << i;
}
return 0;
}
您的代码缺少这部分
// Call the recursive helper function to store Topological
// Sort starting from all vertices one by one
for (int i = 0; i < V; i++)
if (visited[i] == false)
topologicalSortUtil(i, visited, Stack);
来自链接的代码。 当您仅从例如开始时
4
,您可以在链接的绘图中验证示例图中只有 0
和 1
是可到达的。