LintCode_拓扑排序_DFS实现

给定一个有向图,图节点的拓扑排序被定义为:

  • 对于每条有向边A--> B,则A必须排在B之前  
  • 拓扑排序的第一个节点可以是任何在图中没有其他节点指向它的节点  

找到给定图的任一拓扑排序


 注意事项

你可以假设图中至少存在一种拓扑排序

样例

对于下列图:


这个图的拓扑排序可能是:

[0, 1, 2, 3, 4, 5]

或者

[0, 2, 3, 1, 5, 4]

或者

....

下面用递归思想和深度优先搜索实现拓扑排序的算法。

#include <algorithm>
using namespace std;
/**
 * Definition for Directed graph.
 * struct DirectedGraphNode {
 *     int label;
 *     vector<DirectedGraphNode *> neighbors;
 *     DirectedGraphNode(int x) : label(x) {};
 * };
 */
const int MAX=99999;
class Solution {
public:
    /**
     * @param graph: A list of Directed graph node
     * @return: Any topological order for the given graph.
     */
    bool Visited[MAX]; //标记是否被访问过
    vector<DirectedGraphNode*> result;
    void dfs(DirectedGraphNode* r)
    {
        Visited[r->label]=true; //标记已经访问过
        for(int i=0;i<r->neighbors.size();i++) //遍历所有的邻居
        {
            if(!Visited[r->neighbors[i]->label]) //如果邻居没有被访问过,则深入访问
                dfs(r->neighbors[i]);
        }
        result.push_back(r); //将访问结束的顶点添加到vecotr
    }
    vector<DirectedGraphNode*> topSort(vector<DirectedGraphNode*> graph) {
        for(int i=0;i<graph.size();i++)
           if(!Visited[graph[i]->label])
            dfs(graph[i]);
        reverse(result.begin(),result.end());  //记得逆向
        return result;
    }
};

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DFS算法实现拓扑排序的代码如下所示: ```java package com.sh.zfc.graph.bfs; import org.junit.Test; import java.util.Arrays; import java.util.Stack; import static org.junit.Assert.*; public class TopSortTest { @Test public void dfs() { Digraph.GraphVertex\[\] vertices = new Digraph.GraphVertex\[4\]; vertices\[0\] = new Digraph.GraphVertex("A" , Arrays.asList(1,3)); vertices\[1\] = new Digraph.GraphVertex("B" , Arrays.asList(2,3)); vertices\[2\] = new Digraph.GraphVertex("C" ); vertices\[3\] = new Digraph.GraphVertex("D" ); Digraph<String> di = new Digraph<>(vertices); TopSort topsort = new TopSort(di); topsort.topSortByDFS(di); Stack<Integer> result = topsort.getReversePost(); Stack<Integer> expect = new Stack<>(); expect.push(2); expect.push(3); expect.push(1); expect.push(0); assertEquals(expect,result); } } ``` 这段代码使用了DFS算法来实现拓扑排序。首先创建了一个有向图,然后通过DFS算法进行拓扑排序。最后,将排序结果与预期结果进行比较,以验证算法的正确性。 #### 引用[.reference_title] - *1* [浅谈拓扑排序(基于dfs算法)](https://blog.csdn.net/langzitan123/article/details/79687736)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [算法之拓朴排序DFS实现](https://blog.csdn.net/tony820418/article/details/84588614)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [拓扑排序(topological sort)DFS](https://blog.csdn.net/Tczxw/article/details/47334785)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值