图的两种遍历方式:
图的遍历算法里,处理临时数据,依赖两个抽象数据结构:
广度优先遍历也叫层序遍历,先遍历第一层(节点 1),再遍历第二层(节点 2,3,4),第三层(5,6,7,8),第四层(9,10)。
从根结点出发,一直向左子节点走,直到左子节点不存在然后返回到上一个节点走这个节点的右子节点,然后一直往右子节点走,同样的也是走不通为止就返回。很显然这种一路走到黑,黑了就回头的方式,就是深度优先遍历的过程。
广度搜索中,存储下层的数据需要用到队列,
深度搜索中,存储一整条路径的数据,需要用到栈 ,用栈去回溯到最开始的顶点,
具体步骤去看《秒懂算法:用常识解读数据结构》,我觉得书分解得很详细了,不需要在搬一次了。
我面试过挺多次的,很多面试问题都慢慢淡忘了,但是有一个问题一直记得:
他问,你平时在做爬虫的时候,用深度还是广度?
现在回想起来,觉得他问得真扯淡。
为什么?
选择深度或广度所对应的是不同场景,理论上来说,所有问题,都可以用list解决,但是为什么还要分化出那么多的数据结构?
还不是因为——不同的问题,采用不同的数据结构,这样解决效率才高,资源才省。
比如看这个下面这个家族结构图:
如果想要找到曾祖母Ruby的所有儿女,那么用深度还是广度?
如果想要找到Ruby的一个叫Ruth的后代,用深度还是广度?
在思考用深度还是广度时?应该是先思考究竟是想先尽可能在初始顶点附近搜索,还是想先尽可能远离它?
所以,为什么我现在觉得那个问得很扯淡,就类似,小明,你开发喜欢用list还是Map呀?
- -。