码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 总结篇:二叉树遍历


    目录

    1.  前言

    2.  二叉树存储结构

    3.  遍历命名方式

    4.  前序遍历 (Pre-Order Traversal)

    5.  中序遍历 (In-Order Traversal)

    6.  后序遍历 (Post-Order Traversal)

    7.  总结


    1.  前言

    !FBI WARNING!

    本文旨在于以通俗易懂地方式阐述二叉树遍历方法

    什么是二叉树?

    二叉树(Binary Tree)是每个节点最多只有两个分支的树结构,通常分支被称作“左子树”或“右子树”,不能随意颠倒。

    2.  二叉树存储结构

    二叉树可以用数组或链接串列来存储,若是满二叉树就能紧凑排列而不浪费空间。

    一图解百惑,上图!

    二叉树通常用树结点结构来存储。使用链表能避免顺序存储浪费空间的问题,算法和结构相对简单。

    一图解百惑,上图!

    3.  遍历命名方式

    遍历命名方式,源于其访问节点的顺序。最简单的划分:是深度优先(先访问子节点,再访问父节点,最后是第二个子节点)?还是广度优先(先访问第一个子节点,再访问第二个子节点,最后访问父节点)? 

    广度优先搜索算法(Breadth-First Search,BFS)是一种暴力搜索算法,从根节点开始,沿着树的宽度遍历树的节点,如果所有节点均被访问,则算法中止。

    深度优先搜索算法(Depth-First-Search,DFS)是一种用于遍历或搜索树或图的算法。当节点的所在边都己被探寻过,搜索将回溯到发现节点的那条边的起始节点,这一过程一直进行到已发现从源节点可达的所有节点为止。

    一图解百惑,上图! 

    深度优先可进一步按照根节点相对于左右子节点的访问先后来划分。对广度优先而言,遍历没有前序中序后序之分:给定一组已排序的子节点,其“广度优先”的遍历只有一种唯一的结果。

    4.  前序遍历 (Pre-Order Traversal)

    如果把左节点和右节点的位置固定不动,那么根节点放在左节点的左边,称为前序(Pre-order)。

    一图解百惑,上图!

    话不多说,上代码!二叉树的前序遍历(Python)

    5.  中序遍历 (In-Order Traversal)

    根节点放在左节点和右节点的中间,称为中序(In-order)。

    一图解百惑,上图! 

    话不多说,上代码!二叉树的中序遍历(Python)

    6.  后序遍历 (Post-Order Traversal)

    根节点放在右节点的右边,称为后序(Post-order)。

    一图解百惑,上图!

    话不多说,上代码!二叉树的后序遍历(Python)

    7.  总结

    前序:根左右

    中序:左根右

    后序:左右根

    后续还会更新,敬请期待!

  • 相关阅读:
    【猿灰灰赠书活动 - 04期】- 【分布式统一大数据虚拟文件系统——Alluxio原理、技术与实践】
    【Java】之继承
    Spring的声明式事务
    【MySQL新手到通关】第一章 数据库概述
    Java8中Stream详细用法大全
    SpringBoot+SpringSecurity+JWT
    刷题记录:牛客NC13230合并回文子串
    go语法入门2
    【21天学习挑战赛—经典算法】索引查找
    点云绪论(点云数据及获取、点云数据处理、常用软件及开源库)
  • 原文地址:https://blog.csdn.net/m0_61661179/article/details/127413526
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号