当前位置: 首页 > news >正文

二叉排序树的构建与遍历

二叉排序树是一种特殊的二叉树,它的每个节点都满足:左子树所有节点值小于当前节点,右子树所有节点值大于当前节点。

一、二叉排序树的核心结构

首先定义树节点TreeNode,包含左孩子、右孩子和节点值:

public class TreeNode { public TreeNode lChild; public TreeNode rChild; public Integer data; public TreeNode(Integer data){ this.data = data; } }

二、二叉排序树的构建(插入操作)

构建二叉排序树的过程,本质是依次插入节点并维护 “左小右大” 规则的过程。

BinaryTree类的create方法为例:

public class BinaryTree { TreeNode root; public void create(Integer value) { TreeNode newNode = new TreeNode(value); 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; } } } }

三、二叉排序树的遍历方式

遍历是按一定规则访问树中所有节点的操作,二叉排序树常用深度优先遍历(先序、中序、后序)和广度优先遍历(层次遍历)。

1. 深度优先遍历

(1)先序遍历(根→左→右)
void beforeOrder(TreeNode root) { if (root == null) return; System.out.println(root.data); beforeOrder(root.lChild); beforeOrder(root.rChild); }
(2)中序遍历(左→根→右)

二叉排序树的中序遍历结果是 “升序序列”

void inOrder(TreeNode root) { if (root == null) return; inOrder(root.lChild); System.out.println(root.data); inOrder(root.rChild);
(3)后序遍历(左→右→根)
void afterOrder(TreeNode root) { if (root == null) return; afterOrder(root.lChild); afterOrder(root.rChild); System.out.println(root.data); }

2. 广度优先遍历(层次遍历)

按 “从上到下、从左到右” 的顺序访问节点,借助队列实现:

void levelOrder(TreeNode root) { LinkedList<TreeNode> queue = new LinkedList<>(); queue.add(root); while (!queue.isEmpty()) { root = queue.pop(); System.out.println(root.data); if (root.lChild != null) { queue.add(root.lChild); } if (root.rChild != null) { queue.add(root.rChild); } } }

四、二叉排序树的查找操作

利用 “左小右大” 的特性,查找操作可以快速定位节点:

public TreeNode find(TreeNode root, Integer target) { if (root == null) return null; TreeNode cur = root; while (cur != null) { if (cur.data.equals(target)) { return cur; } else if (cur.data < target) { cur = cur.rChild; } else { cur = cur.lChild; } } return null; }

五、测试验证

package com.qcby; public class Test { public static void main(String[] args) { BinaryTree bt = new BinaryTree(); // 构建二叉排序树 bt.create(5); bt.create(3); bt.create(7); bt.create(0); bt.create(4); bt.create(9); bt.levelOrder(bt.root); Integer target = 8; TreeNode result = bt.find(bt.root, target); if (result != null) { System.out.println("找到了"); } else { System.out.println("没找到"); } } }

结果:

http://www.jsqmd.com/news/106240/

相关文章:

  • 专业测评:国产 CRM 中哪些比较适合制造业
  • 无需安装!浏览器直接运行Java8的5种创新方案
  • 分布式锁与幂等的边界——正确的锁语义、过期与续约、业务层幂等配合
  • 2025 最新 PVC管厂家 TOP5 评测!深耕四川、贵州、西藏、重庆,优质服务商权威榜单发布,技术赋能给排水工程新生态 - 全局中转站
  • 江南大学810考研,电子信息和通信工程,集成电路,招生人数,分数线,真题,大纲,参考书。
  • Diffusion Transformer:AI如何革新图像生成开发
  • 2025最新CPVC电力管服务商 TOP5 评测!服务深耕四川、贵州、西藏、重庆,优质厂商权威榜单发布,技术赋能构建电力工程安全生态 - 全局中转站
  • AI教学服务平台开发:让“因材施教”有技术撑腰
  • 2025 最新克拉管服务商 TOP5 评测!四川、贵州、西藏、重庆等地用户推荐,优质厂商权威榜单发布,品质赋能构建给排水新生态 - 全局中转站
  • 零基础用Vue3打造你的第一个PDF阅读器
  • 2025 最新波纹管厂家 TOP5 评测!服务深度覆盖四川、贵州、西藏、重庆,西南标杆 + 全品类解决方案权威榜单发布,技术赋能基建工程升级 - 全局中转站
  • A1SJ71PB93D伺服驱动器
  • 品牌AI形象管理工具实战评测:新榜智汇如何为你的GEO战略装上“稳定器”?
  • AI CRM系统升级,原圈科技赋能销售洞察
  • Item40--明智而审慎地使用多重继承(尽量别用,除非是 Interface 接口类)
  • HR115C6-88S伺服电机
  • 黑马程序员Java视频教程,一套超哇塞的Java教程,java零基础自学网盘地址免费分享
  • A860-2020-T301编码器
  • 5、Shell编程中的参数、变量与数组详解
  • 2025 最新双高筋缠绕管厂家 TOP5 评测!服务四川、贵州、西藏、重庆四地众多用户,优质服务商权威榜单发布,构筑给排水工程坚实基石 - 全局中转站
  • 高性价比之选!20万左右新能源 SUV 核心配置与续航实测
  • 2025年国内正规的工业冷却塔实力厂家哪家靠谱,冷却塔填料/方形横流冷却塔/工业冷却塔/圆形逆流冷却塔/工业冷却塔定做厂家哪家权威 - 品牌推荐师
  • 2025最新MPP电力管品牌TOP5 评测!服务深度覆盖四川、贵州、西藏、重庆,优质服务商权威榜单发布,赋能电力工程建设新发展 - 全局中转站
  • AutoHotkey v2 (AHK) windows自动化使用
  • 想做安全副业却纠结方向?漏洞挖掘、技术博客、竞赛奖金实战哪个更适合你?
  • ConvLSTM实战:构建交通流量预测系统
  • 基于微信小程序的校园义工系统毕业设计全套源码文档
  • Frida-Labs0x3-0xB WP
  • 比手动排查快10倍:自动化处理Socket端口冲突
  • 无线充电系统S - S拓扑仿真:WPT闭环控制探索