Created
          March 28, 2020 14:52 
        
      - 
      
- 
        Save Ji-Yuhang/42459a97eccc540f41270c7268f20faf to your computer and use it in GitHub Desktop. 
    dfs
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | #include<iostream> | |
| #include<vector> | |
| #include<algorithm> | |
| #include<list> | |
| using namespace std; | |
| static const int MAX = 10000; | |
| vector<int> G[MAX]; | |
| list<int> out; | |
| bool V[MAX]; | |
| int N; | |
| void dfs(int u){ | |
| V[u] = true; | |
| for (int i=0; i< G[u].size(); i++){ | |
| int v = G[u][i]; | |
| if(!V[v]) dfs(v); | |
| } | |
| out.push_front(u); | |
| } | |
| int main(){ | |
| int s, t, M; | |
| cin >> N >> M; | |
| for(int i = 0; i < N; i++){ | |
| V[i] = false; | |
| } | |
| for(int i = 0; i < M; i++){ | |
| cin >> s >> t; | |
| G[s].push_back(t); | |
| } | |
| for(int i = 0; i < N; i++){ | |
| if(!V[i]) dfs(i); | |
| } | |
| for (list<int>::iterator it = out.begin(); it != out.end(); it++){ | |
| cout << *it << endl; | |
| } | |
| return 0; | |
| } | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | const _ = require("lodash"); | |
| class Graph { | |
| constructor(edges) { | |
| this.vertexes = []; | |
| this.nearMap = {} | |
| this.edges = _.clone(edges); | |
| _.forEach(this.edges, edge => { | |
| if (!_.includes(this.vertexes, edge.self_id)){ | |
| this.vertexes.push(edge.self_id); | |
| } | |
| if (!_.includes(this.vertexes, edge.next_id)){ | |
| this.vertexes.push(edge.next_id); | |
| } | |
| }) | |
| // console.log(this.vertexes); | |
| _.forEach(this.vertexes, vertex => { | |
| this.nearMap[vertex] = new Array(); | |
| // console.log({vertex}, this.nearMap) | |
| }); | |
| _.forEach(this.edges, edge => { | |
| // console.log(this.nearMap, edge.self_id); | |
| // this.nearMap[edge.next_id].push(edge.self_id); | |
| this.nearMap[edge.self_id].push(edge.next_id); | |
| }) | |
| this.sort2 = [] | |
| } | |
| TOPOLOGICAL_SORT(){ | |
| this.globalTime = 1; | |
| this.nodes = _.map(this.vertexes, vertex=>({id: vertex, color: 'white'})) | |
| _.forEach( this.nodes, node => { | |
| if (node.color == 'white'){ | |
| this.DFS_VISIT(node) | |
| } | |
| }) | |
| console.log(this.nodes); | |
| const sortedNodes = _.sortBy(this.nodes, 'f_time') | |
| console.log(sortedNodes) | |
| console.log(this.sort2); | |
| } | |
| DFS_VISIT(node){ | |
| this.globalTime += 1 | |
| node.d_time = this.globalTime | |
| node.color = 'gray' | |
| console.log("VISIT", node.id); | |
| // console.log("near:",this.nearMap[node.id]); | |
| _.forEach( this.nearMap[node.id], (near_id) => { | |
| let near_node = _.find(this.nodes, {id: near_id}); | |
| // console.log("near_node:",near_node); | |
| if (near_node && near_node.color == 'white') { | |
| // node.children.push(child) | |
| // child.pi = node | |
| this.DFS_VISIT(near_node) | |
| } | |
| }) | |
| node.color = 'black' | |
| this.globalTime += 1 | |
| node.f_time = this.globalTime | |
| this.sort2.unshift(node) | |
| } | |
| } | |
| let edges = [ | |
| { self_id: 0, next_id: 1 }, | |
| { self_id: 1, next_id: 2 }, | |
| { self_id: 3, next_id: 1 }, | |
| { self_id: 3, next_id: 4 }, | |
| { self_id: 4, next_id: 5 }, | |
| { self_id: 5, next_id: 2 }, | |
| ] | |
| let g = new Graph(edges); | |
| console.log(g); | |
| g.TOPOLOGICAL_SORT(); | |
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment