数据结构之二叉树

一 树的简介
树是一种非线性的数据结构,每个数据元素可能与零个或者多个数据元素发生联系
树中每个元素称为结点,为了体现结点之间的关系,分为父节点,子节点,兄弟节点,叶节点,为了更直观的了解这几个基本概念,我们看下图。
在这里插入图片描述
概念 解析
节点的深度 根节点到此节点所经历边的个数
节点的层数 节点的深度+1
树的高度 根节点的高度
节点的高度 节点到叶子节点的最长路径
在这里插入图片描述
二 二查树简介
二叉树,在树的基础上加了属性词"二叉",两个分支,其实上面咱们所画的树就是二叉树。那么特殊的二叉树值得注意的是完全二叉树和满二叉树,如下图所示
在这里插入图片描述
三 二叉树存储方式
3.1 链表存储
我们了解了二叉树的一点基本概念后,为了表示节点之间的关系,引入链表结构,用左右两个指针分别指向左节点和右节点,这样就可以串联整个二叉树,如下图所示。
在这里插入图片描述
3.2 数组存储方式
我们知道数组最大的一个特点就是内存连续,方便随机访问,下标通常从0开始。好了,知道这些我们就先看看用数组如何存储一棵二叉树。
在这里插入图片描述
上图我们假设A元素下标为1(机智的小伙伴看到下标是不是就想到了数组下标),那么它左节点B=21=2,右节点c=21+1=3,依次推理,假设元素p的下标为i,那么元素p的左节点为2i,右节点为2i+1.那么对应于数组是怎样的呢,如下图所示。
在这里插入图片描述
3.2 二叉树存储方式小结
上面使用了数组和链表两种方式对二叉树进行存储。如果为完全二叉树,链表存储每个节点需要多两个左右指针,而对数组而言简直是“天籁之音”,它只需要浪费一个如上图下标为0的存储位置。
四 二查树的遍历
4.1 前序遍历
套路:先访问根节点,再访问左子树,最后访问右子树
在这里插入图片描述
4.2 中序遍历
套路:先访问左子树,再访问根节点,最后访问右子树
在这里插入图片描述
在这里插入图片描述
4.3 后序遍历
套路: 先访问左子树,再访问右子树,最后访问根节点在这里插入图片描述
4.4 层次遍历
套路:逐层遍历
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值