初识数据结构——二叉树从基础概念到实践应用

初识数据结构——二叉树从基础概念到实践应用


数据结构专栏 ⬅(click)

初识二叉树:从基础概念到实践应用🌳

一、树型结构基础

1.1 树的基本概念

在这里插入图片描述

树是一种非线性的数据结构,由n(n>0)个有限节点组成一个具有层次关系的集合。它看起来像一棵倒挂的树,根朝上而叶朝下。

关键特点:有且仅有一个根节点,没有前驱节点除根节点外,其余节点被分成M(M>0)个互不相交的子树树是递归定义的
重要术语结点的度:一个结点含有子树的个数树的度:树中所有结点度的最大值叶子结点:度为0的结点双亲结点/父结点:含有子结点的结点孩子结点/子结点:一个结点含有的子树的根结点根结点:没有双亲结点的结点结点的层次:从根开始定义,根为第1层树的高度/深度:树中结点的最大层次

1.2 树的表示方法

最常用的表示方法是孩子兄弟表示法

classNode{int value;// 树中存储的数据Node firstChild;// 第一个孩子引用Node nextBrother;// 下一个兄弟引用}
在这里插入图片描述

二、二叉树详解

2.1 二叉树概念

二叉树是结点的一个有限集合,该集合:

  1. 或者为空
  2. 或者由一个根节点加上两棵分别称为左子树和右子树的二叉树组成

特点

  • 二叉树不存在度大于2的结点

二叉树的子树有左右之分,次序不能颠倒,是有序树

在这里插入图片描述

2.2 特殊二叉树

  1. 满二叉树:每层的结点数都达到最大值。层数为K,结点总数是2^K-1

完全二叉树:深度为K,有n个结点的二叉树,当且仅当其每一个结点都与深度为K的满二叉树中编号从0至n-1的结点一一对应

在这里插入图片描述

2.3 二叉树的性质

  1. 非空二叉树的第i层最多有2^(i-1)个结点
  2. 深度为K的二叉树最大结点数是2^K-1
  3. 对于任何二叉树,n0(叶子结点) = n2(度为2的结点) + 1
  4. 具有n个结点的完全二叉树深度为⌈log₂(n+1)⌉
  5. 完全二叉树的父子结点关系:
    • 父结点序号:(i-1)/2
    • 左孩子序号:2i+1
    • 右孩子序号:2i+2

2.4 二叉树的存储

链式存储
// 孩子表示法classNode{int val;// 数据域Node left;// 左孩子引用,常常代表左孩⼦为根的整棵左⼦树 Node right;// 右孩子引用,常常代表右孩⼦为根的整棵右⼦树 }// 孩子双亲表示法classNode{int val;Node left;// 左孩子引用,常常代表左孩⼦为根的整棵左⼦树 Node right;// 右孩子引用,常常代表右孩⼦为根的整棵右⼦树 Node parent;// 当前节点的根节点}

三、二叉树遍历

遍历(Traversal)是指沿着某条搜索路线,依次对树中每个结点均做⼀次且仅做⼀次访问。访问结点所做的操作依赖于具体的应⽤问题(比如:打印节点内容、节点内容加1)。遍历是⼆叉树上最重要的操作之一,是二叉树上进行其它运算之基础。

在这里插入图片描述

3.1 递归遍历

  1. (NLR)前序遍历:根节点 -> 左子树 -> 右子树
  2. (LNR)中序遍历:左子树 -> 根节点 -> 右子树

(LRN)后序遍历:左子树 -> 右子树 -> 根节点

在这里插入图片描述
// 前序遍历voidpreOrder(Node root){if(root ==null)return;System.out.print(root.val +" ");preOrder(root.left);preOrder(root.right);}// 中序遍历voidinOrder(Node root){if(root ==null)return;inOrder(root.left);System.out.print(root.val +" ");inOrder(root.right);}// 后序遍历voidpostOrder(Node root){if(root ==null)return;postOrder(root.left);postOrder(root.right);System.out.print(root.val +" ");}

3.2 层序遍历

从根节点出发,按层次从上到下、从左到右访问结点。

voidlevelOrder(Node root){if(root ==null)return;Queue<Node> queue =newLinkedList<>(); queue.offer(root);while(!queue.isEmpty()){Node cur = queue.poll();System.out.print(cur.val +" ");if(cur.left !=null) queue.offer(cur.left);if(cur.right !=null) queue.offer(cur.right);}}

四、二叉树基本操作

代码示例:

// 获取节点个数intsize(Node root){if(root ==null)return0;return1+size(root.left)+size(root.right);}// 获取叶子节点个数intgetLeafNodeCount(Node root){if(root ==null)return0;if(root.left ==null&& root.right ==null)return1;returngetLeafNodeCount(root.left)+getLeafNodeCount(root.right);}// 获取第k层节点个数intgetKLevelNodeCount(Node root,int k){if(root ==null|| k <=0)return0;if(k ==1)return1;returngetKLevelNodeCount(root.left, k-1)+getKLevelNodeCount(root.right, k-1);}// 获取二叉树高度intgetHeight(Node root){if(root ==null)return0;return1+Math.max(getHeight(root.left),getHeight(root.right));}// 查找值为val的节点Nodefind(Node root,int val){if(root ==null)returnnull;if(root.val == val)return root;Node left =find(root.left, val);if(left !=null)return left;returnfind(root.right, val);}

结语

二叉树是数据结构中的核心内容,掌握好二叉树对于理解更复杂的数据结构和算法至关重要。建议读者在学习理论的同时,多动手实现代码,解决实际问题,才能真正掌握二叉树的精髓。


在这里插入图片描述

Read more

我和 AI 聊了一晚上,第二天它说“你好,请问有什么可以帮你?“凌晨我的 AI 尽然悄悄把记忆清空了!——OpenClaw Session 完全生存指南:重置、压缩、剪枝、记忆一网打尽

凌晨4点,我的 AI 悄悄把记忆清空了——OpenClaw Session 避坑指南 摘要:用 OpenClaw 搭了个 AI 助手,聊得好的,第二天一早它就"失忆"了?本文从一个真实踩坑出发,系统拆解 OpenClaw 的 Session 机制——重置(Reset)、压缩(Compaction)、剪枝(Pruning)、记忆(Memory)、会话控制(Session Tool)——帮你彻底搞懂"对话为什么会消失"以及"怎么让 AI 记住你"。 🤯 踩坑现场 事情是这样的: 我用 OpenClaw

By Ne0inhk

AI世界模型(World Model)全解析:技术原理、研究进展与产业落地

AI世界模型(World Model)全解析:技术原理、研究进展与产业落地 摘要:世界模型(World Model)作为连接AI感知、决策与行动的核心枢纽,正成为突破通用人工智能(AGI)瓶颈的关键技术。本文从概念溯源、理论基础出发,系统剖析世界模型的技术架构、核心分类与实现方法,结合2024-2026年最新研究成果(如LeCun团队潜在动作世界模型、DIAMOND扩散模型)与产业落地案例,深入探讨其在强化学习、游戏开发、自动驾驶、机器人等领域的应用价值,最后梳理当前技术挑战并展望未来研究方向。全文兼顾学术深度与工程实践,为AI研究者与技术从业者提供全面的世界模型知识体系。 一、引言:从“符号拟合”到“世界理解”,AI的认知革命 1.1 大语言模型的认知瓶颈 自ChatGPT掀起大模型浪潮以来,大语言模型(LLM)凭借海量文本数据的统计拟合能力,在语义理解、内容生成、逻辑推理等领域展现出惊人实力。但在杨立昆、李飞飞等顶尖学者眼中,当前LLM仍是“

By Ne0inhk
最新 阶跃AI桌面伙伴 完整实操教程:MCP协议配置 + 16款工具集成(Excel/邮箱/飞书/高德自动化)

最新 阶跃AI桌面伙伴 完整实操教程:MCP协议配置 + 16款工具集成(Excel/邮箱/飞书/高德自动化)

一、前置准备(纯操作,无冗余,一键落地) 1.1 软件安装(Windows/macOS通用,直接操作) # 1. 官方下载(国内可直接访问,最新版本2026.01) # Windows:https://www.stepfun.com/download/win # macOS:https://www.stepfun.com/download/mac # 2. 安装步骤(双击安装包,下一步到底,无需自定义路径) # 3. 启动与登录(注册账号,新用户需获取邀请码,社区可免费领取) # 4. 验证启动(启动后出现悬浮球,输入“/test”,提示“连接成功”即为正常) 1.2

By Ne0inhk