⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 _dfsnum.c

📁 数据类型和算法库LEDA 数据类型和算法库LEDA
💻 C
字号:
/*******************************************************************************
+
+  LEDA  3.0
+
+
+  _dfsnum.c
+
+
+  Copyright (c) 1992  by  Max-Planck-Institut fuer Informatik
+  Im Stadtwald, 6600 Saarbruecken, FRG     
+  All rights reserved.
+ 
*******************************************************************************/



/*******************************************************************************
*                                                                              *
*  DFS_NUM (depth first search numbering)                                      *
*                                                                              *
*******************************************************************************/


#include <LEDA/graph_alg.h>

static int dfs_count1,dfs_count2;

static void dfs(node v, node_array<int>& reached, 
                        node_array<int>& dfsnum, 
                        node_array<int>& compnum,
                        list<edge>& T )
{ node w;
  edge e;

  reached[v] = true;
  dfsnum[v] = ++dfs_count1;

  forall_adj_edges(e,v) 
    { w = target(e);
      if (!reached[w]) 
       { T.append(e);
         dfs(w,reached,dfsnum,compnum,T);
        }
     }

  compnum[v] = ++dfs_count2;
} 

list<edge> DFS_NUM(const graph& G, node_array<int>& dfsnum, 
                                   node_array<int>& compnum)
{ 
  list<edge> T;
  node_array<int> reached(G,false);
  node v;
  dfs_count1 = dfs_count2 = 0;
  forall_nodes(v,G) if (!reached[v]) dfs(v,reached,dfsnum,compnum,T);
  return T;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -