赞
踩
算法基本思想:
深度优先搜索是尽可能深的搜索一个图,对于一个新发现的节点,如果还有以此为起点还未探测到的边,就沿此边探测下去。
当顶点v的所有边都被探寻过后,搜索将回溯到发现顶点v的起始点的那些边。这一过程一直进行到一发现从原点可达的所有点为止。
如果还存在未发现的顶点,则选择其中一个座位源顶点,重复上过程。
递归实现
- void DFS_Search(ListNode* pRoot)
- {
- if(!pRoot) return;
- visit(pRoot);
- pRoot->visited = true;
- foreach(ListNode* pChild in pRoot->adjacent)
- if(!pChild->visited)
- DFS_Seach(pChild);
- }
-
非递归实现
- #include <iostream>
- #include <stack>
- using namespace std;
-
- #define MaxNode 20
- #define MAX 2000
- #define StartNode 1
-
- int map[MaxNode+1][MaxNode+1];
-
- void dfs_stack(int start, int n){
- int visited[MaxNode],s_top;
- for(int i = 0;i <= MaxNode; i++){
- visited[i] = 0;
- }
- visited[start] = 1;
- stack <int> s;
- cout<<start<<" ";
- for(int i = 1; i <&#
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。