[javaSE] 数据结构(二叉树-遍历与查找)
前序遍历:中,左,右
中序遍历:左,中,右
后序遍历:左,右,中
二叉树查找
从根节点进行比较,目标比根节点小,指针移动到左边
从根节点进行比较,目标比根节点大,指针移动到右边
/** * 前序遍历 * @param tree */ public void preOrder(BSTree tree){ preOrder(tree.mRoot); } public void preOrder(BSTNode node){ if(node!=null){ System.out.print(node.key+""); preOrder(node.left); preOrder(node.right); } } /** * 中序遍历 * @param tree */ public void midOrder(BSTree tree){ midOrder(tree.mRoot); } public void midOrder(BSTNode node){ if(node!=null){ midOrder(node.left); System.out.print(node.key+""); midOrder(node.right); } } /** * 后序遍历 * @param tree */ public void postOrder(BSTree tree){ postOrder(tree.mRoot); } public void postOrder(BSTNode node){ if(node!=null){ postOrder(node.left); postOrder(node.right); System.out.print(node.key+""); } } /** * 二叉树的查找 * @param tree * @param key * @return */ public BSTNode<T> search(BSTree<T> tree,T key){ BSTNode<T> mRoot=tree.mRoot; while(mRoot!=null){ int flag=key.compareTo(mRoot.key); if(flag<0){ mRoot=mRoot.left; }else if(flag>0){ mRoot=mRoot.right; }else{ return mRoot; } } return mRoot; }
tree.preOrder(tree);//输出 312546 tree.midOrder(tree);//输出 123456 tree.postOrder(tree);//输出 214653 BSTree.BSTNode node=tree.search(tree, 5); System.out.println(node.left.key);//输出 4
十年开发经验程序员,离职全心创业中,历时三年开发出的产品《唯一客服系统》
一款基于Golang+Vue开发的在线客服系统,软件著作权编号:2021SR1462600。一套可私有化部署的网站在线客服系统,编译后的二进制文件可直接使用无需搭开发环境,下载zip解压即可,仅依赖MySQL数据库,是一个开箱即用的全渠道在线客服系统,致力于帮助广大开发者/公司快速部署整合私有化客服功能。
开源地址:唯一客服(开源学习版)
官网地址:唯一客服官网
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具