news 2026/6/15 13:41:45

数据结构基础:二叉排序树创建、遍历与查找算法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构基础:二叉排序树创建、遍历与查找算法

一、二叉排序树概述

二叉排序树是一种特殊的二叉树,满足左子树节点值小于根节点值,右子树节点值大于根节点值。

如图中所示


二、二叉排序树的创建

1.我们先定义一个节点的数据结构TreeNode,一个节点包含左右孩子指针和数据项。

public class TreeNode { public TreeNode lchild; public TreeNode rchild; public Integer data; public TreeNode(Integer data){ this.data = data; } }

2.我们需要一个指针root用来指向树的根节点,还需要一个指针curNode来指向当前判断的节点,除了判断新节点是否大于或小于curNode,还需要判断curNode的左右孩子节点是不是空,如果不是空我们需要循环把curNode指向其孩子节点继续判断,直到curNode的孩子节点为空插入新节点。

以下是代码流程:新插入节点判断

(1)如果root == null,新插入节点作为根节点,不为null进行值的判断

(2)循环判断新插入节点的值是否小于当前节点,如果小往左走直到为null插入

(3)循环判断新插入节点的值是否大于当前节点,如果大往右走直到为null插入

public class BinaryTree { public TreeNode root; public void create(Integer data){ TreeNode newNode = new TreeNode(data); //选择一个节点作为根节点 if(root == null){ root = newNode; return; } TreeNode curNode = root; while(true){ //新节点大于当前判断节点 if(curNode.data < newNode.data){ //判断节点的右孩子节点是空的可以插入,否则右孩子节点做下次判断节点 if(curNode.rchild == null){ curNode.rchild = newNode; return; } curNode = curNode.rchild; }else { //判断节点的左孩子节点是空的可以插入,否则左孩子节点做下次判断节点 if(curNode.lchild == null){ curNode.lchild = newNode; return; } curNode = curNode.lchild; } } } }

三、深度优先遍历

深度优先遍历是指按照某种规则访问树中的所有节点,且每个节点仅访问一次。三种主要的遍历方式:

先序遍历:根节点 → 左子树 → 右子树

中序遍历:左子树 → 根节点 → 右子树

后序遍历:左子树 → 右子树 → 根节点

这里的"先"、"中"、"后"指的是根节点被访问的时机

3.1先序遍历

访问顺序:(1)访问根节点(2)先序遍历左子树(3)先序遍历右子树

//先序遍历 public void beforeOrder(TreeNode root){ if(root == null){ return; } System.out.println(root.data); //访问根节点 beforeOrder(root.lchild); //先序遍历左子树 beforeOrder(root.rchild); //先序遍历右子树 }

我们以上图排序树为例给出遍历过程

(1)访问根节点5

(2)遍历5的左子树(3为根)

访问3

遍历3的左子树(0为根)

访问0,0无左子树,0无右子树

遍历3的右子树(4为根)

访问4,4无左子树,4无右子树

(3)遍历5的右子树(7为根)

访问7

遍历7的左子树(6为根)

访问6;6无左子树;6无右子树

遍历7的右子树(9为根)

访问9;9无左子树;9无右子树

结果:5 3 0 4 7 6 9

先序遍历的输出整体看是从根到左再到右,所以先序遍历适合用在复制树的结构和前缀表达式

3.2中序遍历

访问顺序:(1)中序遍历左子树(2)访问根节点(3)中序遍历右子树

//中序遍历 public void inOrder(TreeNode root){ if(root == null){ return; } inOrder(root.lchild); //中序遍历左子树 System.out.println(root.data); //访问根节点 inOrder(root.rchild); //中序遍历右子树 }

遍历分析过程与上面先序同理,中序遍历上图结果:0 3 4 5 6 7 9

我们不难发现中序遍历结果是顺序的,所以中序遍历适合二叉排序树的有序输出

3.3后续遍历

访问顺序:(1)后序遍历左子树(2)后序遍历右子树(3)访问根节点

//后续遍历 public void afterOrder(TreeNode root){ if(root == null){ return; } afterOrder(root.lchild); //后续遍历左子树 afterOrder(root.rchild); //后续遍历右子树 System.out.println(root.data); //访问根节点 }

遍历上述图结果:0 4 3 6 9 7 5

后序遍历整体输出是从叶子节点到根节点,所以后序遍历适合用在删除树和后缀表达式


四、广度优先遍历

广度优先遍历又称层次遍历,原理是按层次从上到下访问节点,同一层从左到右访问,使用队列(先进先出)保证访问顺序。

以下是代码流程:

(1)根节点先入队

(2)循环执行队列不为空时

1.队头节点出队并访问该节点

2.如果该节点的左孩子节点存在,则左孩子节点入队

3.如果该节点的右孩子节点存在,则右孩子节点入队

(3)直到队列为空

//层次遍历 public void levelOrder(TreeNode root){ LinkedList<TreeNode> linklist = new LinkedList<TreeNode>(); linklist.add(root); while(!linklist.isEmpty()){ root = linklist.pop(); System.out.println(root.data); if(root.lchild != null){ linklist.add(root.lchild); } if (root.rchild != null){ linklist.add(root.rchild); } } }

五、查找算法

二叉排序树的查找可以递归实现,先判断是否为空树,然后判断根节点是否为要找的目标节点,最后判断如果根节点大于目标节点则递归返回把根节点左孩子作为形参,否则递归返回根节点右孩子作为形参。

public TreeNode find(TreeNode root,Integer target){ if(root == null){ return null; } if(Objects.equals(root.data, target)){ return root; } else if(root.data > target){ return find(root.lchild,target); }else { return find(root.rchild,target); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 2:04:51

基于单片机的住宅防火防盗报警系统设计

第一章&#xff1a;系统核心硬件架构与选型 基于单片机的住宅防火防盗报警系统以“全方位监测、快速响应”为设计核心&#xff0c;采用“STC89C52RC单片机多传感检测模块报警执行模块交互模块”的硬件架构&#xff0c;适配普通住宅、小型公寓的安全防护需求。主控芯片选用STC89…

作者头像 李华
网站建设 2026/6/13 16:20:17

基于ZigBee技术的温湿度监测系统设计

一、系统整体架构设计 基于ZigBee技术的温湿度监测系统采用“终端节点-路由节点-协调器-监控中心”四层架构&#xff0c;实现对目标区域的分布式监测。终端节点部署在监测现场&#xff0c;负责采集温湿度数据&#xff0c;每节点配备ZigBee模块&#xff08;CC2530&#xff09;与…

作者头像 李华
网站建设 2026/6/15 11:41:04

Windows 10/11 隐私防护神器 WPD 使用教程:告别数据泄露,小白也能会

软件介绍 WPD 是一款专为 Windows 7 及以上版本设计的隐私保护工具&#xff0c;具有免费、绿色、轻量的特点。 核心功能&#xff1a; 隐私保护&#xff1a;全面管理系统隐私设置&#xff0c;防止个人信息泄露 性能优化&#xff1a;禁用不必要的功能&#xff0c;减轻系统负担…

作者头像 李华
网站建设 2026/6/15 12:47:16

生态震荡——当“摘要”成为终点,知识价值链的重塑与博弈

AI搜索&#xff0c;尤其是其“直接生成答案”的核心形态&#xff0c;在为用户带来极致便利的同时&#xff0c;也像一块巨石投入平静的湖面&#xff0c;对构建互联网二十余年的传统内容生态系统产生了剧烈冲击。这场震荡的核心矛盾在于&#xff1a;AI的“产出”高度依赖于人类的…

作者头像 李华