二叉排序树BST代码(JAVA)
publicclassTest{publicstaticvoid main(String[] args){int[] r =newint[]{5,1,3,4,6,7,2,8,9,0};BST binarySearchTree =new BST(r);binarySearchTree.inOrder();System.out.println();binarySearchTree.searchBST(6);//查找成功System.out.println();binarySearchTree.searchBST(10);//查找失败->插入System.out.println();}}
publicclass BST {//二叉树结点publicclassBiNode{int data;BiNode left;BiNode right;BiNode(int data,BiNode left,BiNode right){this.data = data;this.left = left;this.right = right;}}privateBiNode root = null;BST(int[] r){for(int i =0; i < r.length; i++){BiNode s =newBiNode(r[i],null,null);root = insertBST(root, s);// insertBST1(s);}}//插入(递归)publicBiNode insertBST(BiNode head,BiNode s){if(head == null){head = s;return head;}if(s.data < head.data)head.left = insertBST(head.left, s);elsehead.right = insertBST(head.right,s);return head;}//插入(非递归:循环、用临时变量保存过程)publicvoid insertBST1(BiNode s){if(root == null){root = s;return;}BiNode temp = root;//需要临时结点记录while(true){if(s.data < temp.data){if(temp.left == null){temp.left = s;return;}temp = temp.left;}else{if(temp.right == null){temp.right = s;return;}temp = temp.right;}}}//查找:成功->返回;失败:插入publicBiNode searchBST(int a){BiNode s1 = searchBST(root,a);if(s1 == null){BiNode s2 =newBiNode(a,null,null);insertBST1(s2);System.out.println("search fail ; insert success: "+ s2.data);inOrder();return s2;}else{System.out.println("search success: "+ s1.data);return s1;}}//查找privateBiNode searchBST(BiNode head,int a){if(head == null)return null;if(a < head.data)return searchBST(head.left, a);elseif(a > head.data)return searchBST(head.right, a);elsereturn head;}// 删除// 删除f的孩子ppublicvoid deleteLeftBST(BiNode f,BiNode p){if(p.left == null && p.right == null) //p为叶子{f.left = null;p = null;}elseif(p.right == null) //p只有左子树{f.left = p.left;p = null;}elseif(p.left == null) //p只有右子树{f.left = p.right;p = null;}else //p的左右子树均不空{BiNode par = p, s = par.right; //用par s 去查找p的右子树的最左下结点while(s.left != null){par = s;s = par.left;}p.data = s.data; //交换最左下结点s与p结点数据//剪枝(删除s结点)if(par == p) //处理特殊情况{par.right = s.right;s = null;}else //处理一般情况{par.left = s.right;s = null;}}}//先序遍历publicvoid preOrder(){System.out.print("preOrder traversal with recursion:");preOrder(root);System.out.println();}//递归privatevoid preOrder(BiNode root){if(root == null)return;System.out.print(root.data); //访问结点preOrder(root.left);preOrder(root.right);}//中序遍历publicvoid inOrder(){System.out.print("inOrder traversal with recursion:");inOrder(root);System.out.println();}//递归privatevoid inOrder(BiNode root){if(root == null)//访问结点return;inOrder(root.left);System.out.print(root.data); //访问结点inOrder(root.right);}//后序遍历publicvoid postOrder(){System.out.print("postOrder traversal with recursion:");postOrder(root);System.out.println();}//递归privatevoid postOrder(BiNode root){if(root == null)return;postOrder(root.left);postOrder(root.right);System.out.print(root.data); //访问结点}}
inOrder traversal with recursion:0123456789search success:6search fail ; insert success:10inOrder traversal with recursion:012345678910
二叉排序树BST代码(JAVA)的更多相关文章
- 二叉排序树(BST)创建,删除,查找操作
binary search tree,中文翻译为二叉搜索树.二叉查找树或者二叉排序树.简称为BST 一:二叉搜索树的定义 他的定义与树的定义是类似的,也是一个递归的定义: 1.要么是一棵空树 2.如果 ...
- Atitit.http代理的实现 代码java php c# python
Atitit.http代理的实现 代码java php c# python 1. 代理服务器用途 代理服务器看成是一种扩展浏览器功能的途径.例如,在把数据发送给浏览器之前,可以用代理服务器压缩数据 调 ...
- 二叉排序树(BST)构造与应用
二叉排序树(BST)构造与应用 本文取自<数据结构与算法>(C语言版)(第三版).出版社是清华大学出版社. 本博文作为学习资料整理. 源码是VC+ ...
- 分页 工具类 前后台代码 Java JavaScript (ajax) 实现 讲解
[博客园cnblogs笔者m-yb原创, 转载请加本文博客链接,笔者github: https://github.com/mayangbo666,公众号aandb7,QQ群927113708]http ...
- Java数据结构和算法(五)二叉排序树(BST)
Java数据结构和算法(五)二叉排序树(BST) 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 二叉排序树(Binary S ...
- stl文件格式解析代码--java版
代码是参考three.js中的stlLoader.js写的. 需要注意的地方,java中byte取值-128~127 package test_stl.test_entry; import java. ...
- n皇后2种解题思路与代码-Java与C++实现
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要讲了n皇后问题的解题思路,并分别用java和c++实现了过程,最后,对于算法改进 ...
- 如何写出无法维护的代码(JAVA版)
程序命名(针对那些不能混淆的代码) 容易输入的名字.比如:Fred,asdf 单字母的变量名.比如:a,b,c, x,y,z,或者干脆上中文比如(阿隆索肯德基) 有创意地拼写错误.比如:SetPint ...
- [改善Java代码]Java的泛型是类型擦除的
泛型可以减少强制类型的转换,可规范集合的元素类型,还可以提高代码的安全性和可读性,正是因为有了这些优点,自从Java引入泛型之后,项目的编码规则上便多了一条,优先使用泛型. Java泛型(Generi ...
随机推荐
- 读书笔记 |Google C++编程风格指南
Google C++编程风格指南 ## 0. 背景 每一个C++程序员都知道,C++具有很多强大的语言特性,但这种强大不可避免的导致它的复杂,这种复杂会使得代码更易于出现bug.难于阅读和维护. 本指 ...
- [LeetCode OJ] Candy
There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...
- C++多重继承虚表的内存分布
接前面虚表的内存分布,今天重点看多重继承的虚表内存分布,简单的说,继承几个类便有几个虚表,如下代码 class Drive : public Base1, public Base2, public B ...
- java判断网络连接是否正常
/** * 判断本机当前的网络状态是否联通 * 在这里主要用到中国天气信息,所以访问百度地址是否能够访问成功来判断当前的网络状态 */ public static boolean isConnect( ...
- 002.AngularJs调用Restful实现CRUD
本节我们主要给大家介绍AngularJs如何调用Restful,实现数据的CRUD. 主要用到的技术: 后端:ASP.NET WebApi + SQLServer2008 前端:AngularJs,B ...
- JQUERY1.9学习笔记 之内容过滤器(一) 包含选择器
描述:选择包含指定文本的所有元素.jQuery( ":contains(text)" ) text:一串大小写敏感的文本. 例:找出所有包含"john"的div ...
- ExtJS5_主界面上加入顶部和底部区域
为主界面加一个顶部区域和底部区域.一个管理系统的界面可以粗分为顶部标题部分.中间数据展示和处理的部分.底部备注和状态部分. 在增加这二个区域之前,我们先在MainModel.js中加入一些数据. Ex ...
- 『在线工具』 基于 xsser.me 源码 + BootStrap 前端 的 XSS 平台
乌云社区上一个小伙伴的对xsser.me 的源码做了 BS 的优化,本人已经搭建好,提供给大家免费使用,大牛求绕过,多谢. 地址: http://xss.evilclay.com (目前开放注册,不需 ...
- Gold Balanced Lineup
#include<cstdio> #include<cstring> #include<cmath> #include <cstdlib> #defin ...
- [Android] 混音线程MixerThread
MixerThread是Android音频输出的核心部分,所有Android的音频都需要经过MixerThread进行混音后再输出到音频设备. MixerThread的继承关系如下: MixerThr ...