图/树

您所在的位置:网站首页 什么是dfs算法 图/树

图/树

2023-11-14 17:41| 来源: 网络整理| 查看: 265

转载

深度优先搜索(DFS, Depth First Search)是一个针对图和树的遍历算法。早在19世纪就被用于解决迷宫问题。

对于下面的树而言,DFS方法首先从根节点1开始,其搜索节点顺序是1,2,3,4,5,6,7,8(假定左分枝和右分枝中优先选择左分枝)。 这里写图片描述 DFS的实现方式相比于BFS应该说大同小异,只是把queue换成了stack而已,stack具有后进先出LIFO(Last Input First Output)的特性,DFS的操作步骤如下:  1、把起始点放入stack;  2、重复下述3步骤,直到stack为空为止:

从stack中访问栈顶的点;找出与此点邻接的且尚未遍历的点,进行标记,然后全部放入stack中;如果此点没有尚未遍历的邻接点,则将此点从stack中弹出。

下面结合一个图(graph)的实例,说明DFS的工作过程和原理:  (1)将起始节点1放入栈stack中,标记为已遍历。 这里写图片描述 (2)从stack中访问栈顶的节点1,找出与节点1邻接的节点,有2,8两个节点,我们可以选择其中任何一个,选择规则可以人为设定,这里假设按照节点数字顺序由小到大选择,选中的是2,标记为已遍历,然后放入stack中。 这里写图片描述 (3)从stack中取出栈顶的节点2,找出与节点2邻接的节点,有1,3,5三个节点,节点1已遍历过,排除;3,5中按照预定的规则选中的是3,标记为已遍历,然后放入stack中。 这里写图片描述 (4)从stack中取出栈顶的节点3,找出与节点3邻接的节点,有2,4两个节点,节点2已遍历过,排除;选中的是节点4,标记为已遍历,然后放入stack中。 这里写图片描述 (5)从stack中取出栈顶的节点4,找出与节点4邻接的节点,有3,5,6三个节点,节点3已遍历过,排除;选中的是节点5,标记为已遍历,然后放入stack中。 这里写图片描述 (6)从stack中取出栈顶的节点5,找出与节点5邻接的节点,有2,4两个节点,节点2,4都已遍历过,因此节点5没有尚未遍历的邻接点,则将此点从stack中弹出。 这里写图片描述 (7)当前stack栈顶的节点是4,找出与节点4邻接的节点,有3,5,6三个节点,节点3,5都已遍历过,排除;选中的是节点6,标记为已遍历,然后放入stack中。 这里写图片描述 (8)当前stack栈顶的节点是6,找出与节点6邻接的节点,有4,7,8三个节点,4已遍历,按照规则选中的是7,标记为已遍历,然后放入stack中。 这里写图片描述 (9)当前stack栈顶的节点是7,找出与节点7邻接的节点,只有节点6,已遍历过,因此没有尚未遍历的邻接点,将节点7从stack中弹出。 这里写图片描述 (10)当前stack栈顶的节点是6,找出与节点6邻接的节点,有节点7,8,7已遍历过,因此将节点8放入stack中。 这里写图片描述 (11)当前stack栈顶的节点是8,找出与节点8邻接的节点,有节点1,6,9,1,6已遍历过,因此将节点9放入stack中。 这里写图片描述 (12)当前stack栈顶的节点是9,没有尚未遍历的邻接点,将节点9弹出,依次类推,栈中剩余节点8,6,4,3,2,1都没有尚未遍历的邻接点,都将弹出,最后栈为空。  (13)DFS遍历完成。

 

在二叉树中DFS遍历代码(仅考虑了前序遍历,中后序也可以实现):

// DFS的递归实现 void DFS_Recursive(Node* pRoot) { if (pRoot==NULL) return; coutpRight!=NULL) DFS_Recursive(pRoot->pRight); } // DFS的迭代实现版本(stack) void DFS_Iterative(Node* pRoot) { if (pRoot==NULL) return; stack S; S.push(pRoot); while (!S.empty()) { Node *node=S.top(); coutpLeft!=NULL) { S.push(node->pLeft); } } }

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3