数据结构之二叉树简介

二叉树

二叉树是一种非线性数据结构,代表"祖先"与"后代"之间的派生关系,体现了"一分为二"的分治逻辑。与链表相似,二叉树的基本单元是节点,每个节点包含值,左子节点的索引,右子节点的索引

c++ 复制代码
/* 二叉树节点结构体 */
struct TreeNode {
    int val;          // 节点值
    TreeNode *left;   // 左子节点指针
    TreeNode *right;  // 右子节点指针
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
  • 当给定一个二叉树的节点时,我们将该节点的左子节点及其以下节点形成的树称为该节点的左子树,同理可得,右子节点及其以下节点形成的树称为该节点的右子树。

  • 在给定的二叉树中,除了叶子节点,其他所有节点均包含子节点和非空子树

二叉树的常见术语

  • 根节点:位于二叉树顶层的节点,没有父节点
  • 叶子节点:没有字节的的节点,左右指针均为null
  • 边:连接两个节点的线段,
  • 节点所在的层:从顶到底递增,根节点的层数为1
  • 节点的度:节点的字节点的个数,在二叉树中,节点的度的取值范围:0,1,2
  • 二叉树的高度:从根节点到最远叶子节点所经过的边的数量
  • 节点的深度:从根节点到该节点边的数量
  • 节点的高度:从最远的叶子节点到该节点边的数量

二叉树的基本操作

c++ 复制代码
/* 初始化二叉树 */
// 初始化节点
TreeNode* n1 = new TreeNode(1);
TreeNode* n2 = new TreeNode(2);
TreeNode* n3 = new TreeNode(3);
TreeNode* n4 = new TreeNode(4);
TreeNode* n5 = new TreeNode(5);
// 构建节点之间的引用(指针)
n1->left = n2;
n1->right = n3;
n2->left = n4;
n2->right = n5;
c++ 复制代码
/* 插入与删除节点 */
TreeNode* P = new TreeNode(0);
// 在 n1 -> n2 中间插入节点 P
n1->left = P;
P->left = n2;
// 删除节点 P
n1->left = n2;

常见二叉树的类型

  • 完美二叉树:**所有层的节点都被填满。**所有叶子节点的度为0,其余所有节点的度为2
  • 完全二叉树:只有最底层的节点没有被填满并且最底层的节点靠左填满
  • 完满二叉树:除了叶子节点外,其余所有节点的度为2
  • 平衡二叉树:任意节点的左子树和右子树的高度之差的绝对值不超过1
相关推荐
Fanxt_Ja3 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
今后1233 天前
【数据结构】二叉树的概念
数据结构·二叉树
散1123 天前
01数据结构-01背包问题
数据结构
消失的旧时光-19433 天前
Kotlinx.serialization 使用讲解
android·数据结构·android jetpack
Gu_shiwww3 天前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
苏小瀚3 天前
[数据结构] 排序
数据结构
睡不醒的kun3 天前
leetcode算法刷题的第三十四天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
吃着火锅x唱着歌3 天前
LeetCode 978.最长湍流子数组
数据结构·算法·leetcode
Whisper_long4 天前
【数据结构】深入理解堆:概念、应用与实现
数据结构
IAtlantiscsdn4 天前
Redis7底层数据结构解析
前端·数据结构·bootstrap