数据结构与算法——二叉树(上)

简介: 前面说到的几种数据结构都是线性的,例如链表、栈、队列等,今天就来学习一种非线性的数据结构——树。

1. 什么是树?


前面说到的几种数据结构都是线性的,例如链表、栈、队列等,今天就来学习一种非线性的数据结构——树。先来看看几种树的结构:

有没有发现,其实树这种结构跟我们现实生活中的“树”非常的相似,像上图中的这棵“树”,节点 A 称作 B 和 C 的父节点,节点 B 和 C 在同一级,叫做兄弟节点。没有父节点的 A 节点叫做根节点,没有子节点的节点叫做叶子节点或叶节点,例如图中的 D E F G。

树的节点还涉及到三个概念,分别是高度、深度、层。

节点高度:节点到叶子节点的最长路径

节点深度:根节点到这个节点所经历的边的个数

节点的层:节点深度 + 1

树的高度:根节点的高度

结合下面的图你就能够理解了,高度是从下到上数的,深度是从上到下数的:


2. 二叉树


树的形态多种多样,但是我们平常最常用的还是二叉树,顾名思义,二叉树就是每个节点最多只有两个子节点的树。

在上图中的几种二叉树中,有两个是比较特殊的,分别是满二叉树和完全二叉树

满二叉树:树的叶子节点全在最底层,并且除了叶子节点,每个节点都有左右两个子节点,例如上图中的树 2。

完全二叉树:叶子节点都在最底下两层,最底层的节点全都靠左排列,并且除了最后一层,其他层的节点都必须有左右两个节点,例如上图中的树 3。

完全二叉树的概念有点不太好理解,你可以多思考一下,其实满二叉树就是完全二叉树的一种特殊情况。完全二叉树的这种特性是为了方便其在数组中的存储,不至于浪费太多的内存空间,等后面说到堆的时候你就更能理解了。

除了使用数组存储二叉树外,最常用的便是使用链表法来储存二叉树了。下面说到的二叉树的遍历便是这种存储方法。


3. 二叉树的遍历


二叉树的一种常见操作就是需要遍历得到树种的全部数据,最常用的遍历方式有三种:前序遍历、中序遍历、后序遍历。

  • 前序遍历:对于树中的任意节点来说,先遍历这个节点,然后遍历这个节点的左子节点,最后遍历这个节点的右子节点。(父左右)
  • 中序遍历:对于树中的任意节点来说,先遍历这个节点的左子节点,然后遍历这个节点本身,最后遍历这个节点的右子节点。(左父右)
  • 后序遍历:对于树中的任意节点来说,先遍历这个节点的左子节点,然后遍历这个节点的右子节点,最后遍历这个节点本身。(左右父)

其实树的遍历是一种很典型的递归操作,代码也可以使用递归来实现,你可以看看我实现的代码。

//1.前序遍历
    public void preOrder(Node head){
        if (head == null) return;
        System.out.print(head.getData() + "  ");
        preOrder(head.left);
        preOrder(head.right);
    }
    //2.中序遍历
    public void midOrder(Node head){
        if (head == null) return;
        midOrder(head.left);
        System.out.print(head.getData() + "  ");
        midOrder(head.right);
    }
    //3.后序遍历
    public void postOrder(Node head){
        if (head == null) return;
        postOrder(head.left);
        postOrder(head.right);
        System.out.print(head.getData() + "  ");
    }
相关文章
|
26天前
|
机器学习/深度学习 存储 算法
数据结构实验之二叉树实验基础
本实验旨在掌握二叉树的基本特性和遍历算法,包括先序、中序、后序的递归与非递归遍历方法。通过编程实践,加深对二叉树结构的理解,学习如何计算二叉树的深度、叶子节点数等属性。实验内容涉及创建二叉树、实现各种遍历算法及求解特定节点数量。
75 4
|
1月前
|
算法
分享一些提高二叉树遍历算法效率的代码示例
这只是简单的示例代码,实际应用中可能还需要根据具体需求进行更多的优化和处理。你可以根据自己的需求对代码进行修改和扩展。
|
1月前
|
存储 缓存 算法
如何提高二叉树遍历算法的效率?
选择合适的遍历算法,如按层次遍历树时使用广度优先搜索(BFS),中序遍历二叉搜索树以获得有序序列。优化数据结构,如使用线索二叉树减少空指针判断,自定义节点类增加辅助信息。利用递归与非递归的特点,避免栈溢出问题。多线程并行遍历提高速度,注意线程安全。缓存中间结果,避免重复计算。预先计算并存储信息,提高遍历效率。综合运用这些方法,提高二叉树遍历算法的效率。
51 5
|
1月前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
122 8
|
1月前
|
机器学习/深度学习 JSON 算法
二叉树遍历算法的应用场景有哪些?
【10月更文挑战第29天】二叉树遍历算法作为一种基础而重要的算法,在许多领域都有着不可或缺的应用,它为解决各种复杂的问题提供了有效的手段和思路。随着计算机科学的不断发展,二叉树遍历算法也在不断地被优化和扩展,以适应新的应用场景和需求。
36 0
|
2月前
|
存储 算法 关系型数据库
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
这篇文章主要介绍了多路查找树的基本概念,包括二叉树的局限性、多叉树的优化、B树及其变体(如2-3树、B+树、B*树)的特点和应用,旨在帮助读者理解这些数据结构在文件系统和数据库系统中的重要性和效率。
29 0
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
|
2月前
|
存储 算法 搜索推荐
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
这篇文章主要介绍了顺序存储二叉树和线索化二叉树的概念、特点、实现方式以及应用场景。
32 0
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
|
2月前
|
Java
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
30 1
|
2月前
|
算法 Java C语言
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)
26 1
|
2月前
|
存储
【数据结构】二叉树链式结构——感受递归的暴力美学
【数据结构】二叉树链式结构——感受递归的暴力美学