【数据结构】图的遍历之DFS和BFS

本文介绍了图这种复杂数据结构,详细阐述了邻接矩阵和邻接表两种常见的图表示方法。接着,重点讨论了图的遍历算法,包括深度优先遍历(DFS)和广度优先遍历(BFS),并提供了程序实例和测试代码进行辅助理解。
摘要由CSDN通过智能技术生成

1.概述

       图是一种比较复杂的数据结构,一个图G = (V,E)是有顶点集合V和边的集合E组成,在计算机中表示图时一般使用邻接矩阵和邻接表。邻接矩阵一个N*N的矩阵,空间复杂度相对较高,所以一般适用于边的数目比较多的稠密图;邻接表一般使用于边的数目较少稀疏图。

2.算法描述

       图的遍历包括深度优先遍历DFS和广度优先遍历BFS,这两种遍历算法在与图相关的问题中是经常使用的中间算法。

       广度优先遍历与深度优先遍历的区别在于:广度优先遍历是以层为顺序,将某一层上的所有节点都搜索到了之后才向下一层搜索;而深度优先遍历是将某一条枝桠上的所有节点都搜索到了之后,才转向搜索另一条枝桠上的所有节点。
       深度优先遍历从某个顶点出发,首先访问这个顶点,然后找出刚访问这个结点的第一个未被访问的邻结点,然后再以此邻结点为顶点,继续找它的下一个新的顶点进行访问,重复此步骤,直到所有结点都被访问完为止。
       广度优先遍历从某个顶点出发,首先访问这个顶点,然后找出这个结点的所有未被访问的邻接点,访问完后再访问这些结点中第一个邻接点的所有结点,重复此方法,直到所有结点都被访问完为止。
       可以看到两种方法最大的区别在于前者从顶点的第一个邻接点一直访问下去再访问顶点的第二个邻接点;后者从顶点开始访问该顶点的所有邻接点再依次向下
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值