深入理解栈和队列, BFS & DFS

若文章对你有帮助请点个👍👍👍, 表示对我的鼓励, 非常感谢 ❤️❤️❤️

背景

为了让程序有自己的灵魂, 以及锻炼自己的思维逻辑能力. 特此学习了下Leetcode的栈和队列, 受益良多, 因此写下感受来使更多人看见, 方便他人. 欢迎大家提意见.

面向刚刷leetcode的新人和对数据结构不了解的人.

队列的基本概念

队列的基本思想就是先入队的最先出队(FIFO).

队列基本概念

入队

基于上图中, 往队列中加入一个元素.
1

出队

从队列中移除一个元素.
2

3

栈的基本概念

栈与队列相反, 栈是先入后入的数据结构(FILO).

在这里插入图片描述

入栈

栈的元素入栈之后, 落入栈的顶端.

出栈

出栈的元素从栈顶进行移出.
5

6

BFS的基本概念

BFS是广度优先搜索, 该算法主要是用来遍历树和图. 它的基本思想是从根节点开始, 依次遍历距离根节点最近的节点.

7

所以上图的广度优先遍历顺序为: 1, 2, 3, 4, 5, 6, 7

DFS的基本概念

DFS是深度优先搜索, 也是用来遍历树和图. 它的基本思想是从根节点开始访问, 然后尽可能地往深处访问. 如果发现已经访问到叶子节点或者该节点的分支已经全部访问, 则回溯到父节点.

假设有一树如下图所示, 现在要用DFS访问该树的所有节点.

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值