File: depth_first_search.txt

package info (click to toggle)
python-networkx 1.1-2
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 2,780 kB
  • ctags: 1,910
  • sloc: python: 29,050; makefile: 126
file content (30 lines) | stat: -rw-r--r-- 526 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
Search 
======

>>> from networkx import *

simple graph

>>> G=Graph()

>>> G.add_edges_from([(0,1),(1,2),(1,3),(2,4),(3,4)])

A dfs preorder - there are many

>>> dfs_preorder(G,source=0)
[0, 1, 2, 4, 3]

>>> dfs_postorder(G,source=0)
[3, 4, 2, 1, 0]

>>> dfs_successor(G,source=0)
{0: [1], 1: [2], 2: [4], 3: [], 4: [3]}

>>> dfs_predecessor(G,source=0)
{0: [], 1: [0], 2: [1], 3: [4], 4: [2]}

>>> T=dfs_tree(G,source=0)
>>> sorted(T.nodes())==sorted(G.nodes())
True
>>> sorted(T.edges())
[(0, 1), (1, 2), (2, 4), (4, 3)]