Java对二叉搜索树进行插入、查找、遍历、最大值和最小值的操作
1、首先,须要一个节点对象的类。这些对象包括数据。数据代表存储的内容,并且还有指向节点的两个子节点的引用
- class Node {
- public int iData;
- public double dData;
- public Node leftChild;
- public Node rightChild;
- public void displayNode() {
- System.out.print("{");
- System.out.print(iData);
- System.out.print(",");
- System.out.print(dData);
- System.out.print("}");
- }
- }
2、插入一个节点
从根開始查找一个对应的节点,它将是新节点的父节点。
当父节点找到了,新节点就能够连接到它的左子节点或右子节点处。这取决于新节点的值是比父节点的值大还是小。
以下是insert()方法代码:
- public void insert(int id, double dd) {
- Node newNode = new Node();
- newNode.iData = id;
- newNode.dData = dd;
- if(root == null)
- root = newNode;
- else {
- Node current = root;
- Node parent;
- while(true) {
- parent = current;
- if(id < current.iData) {
- current = current.leftChild;
- if(current == null) {
- parent.leftChild = newNode;
- return;
- }
- } else {
- current = current.rightChild;
- if(current == null) {
- parent.rightChild = newNode;
- return;
- }
- }
- } // end while
- } // end else
- }
这里用一个新的变量parent(current的父节点),来存储遇到的最后一个不是null的节点。必须这样做,由于current在查找的过程中会变成null,才干发现它查过的上一个节点没有一个相应的子节点。
假设不存储parent。就会失去插入新节点的位置。
3、查找一个节点
- public Node find(int key) {
- // 如果树非空
- Node current = root;
- while(current.iData != key) {
- if(key < current.iData)
- current = current.leftChild;
- else
- current = current.rightChild;
- if(current == null)
- return null;
- }
- return current;
- }
找到节点:假设while循环不满足条件,从循环的末端退出来。current的iData字段和key相等,这就找到了该节点。
找不到节点:假设current等于null。在查找序列中找不到下一个子节点,到达序列的末端而没有找到要找的节点。表明了它不存在。返回nulll来指出这个情况。
4、遍历树(前序遍历。中序遍历,后序遍历)
- /**
- * 前序遍历
- * @param localRoot
- */
- public void preOrder(Node localRoot) {
- if(localRoot != null) {
- System.out.print(localRoot.iData+" ");
- preOrder(localRoot.leftChild);
- preOrder(localRoot.rightChild);
- }
- }
- /**
- * 中序遍历
- * @param localRoot
- */
- public void inOrder(Node localRoot) {
- if(localRoot != null) {
- preOrder(localRoot.leftChild);
- System.out.print(localRoot.iData+" ");
- preOrder(localRoot.rightChild);
- }
- }
- /**
- * 后序遍历
- * @param localRoot
- */
- public void postOrder(Node localRoot) {
- if(localRoot != null) {
- preOrder(localRoot.leftChild);
- preOrder(localRoot.rightChild);
- System.out.print(localRoot.iData+" ");
- }
- }
遍历树的最简单方法使用递归的方法。
用递归的方法遍历整棵树要用一个节点作为參数。初始化这个节点是根。比如中序遍历仅仅须要做三件事:
1)、调用自身来遍历节点的左子树
2)、訪问这个节点
3)、调用自身来遍历节点的右子树。
5、查找最大值和最小值
- /**
- * 求树中的最小值
- * @return
- */
- public Node minimum() {
- Node current;
- current = root;
- Node last = null;
- while(current != null) {
- last = current;
- current = current.leftChild;
- }
- return last;
- }
- /**
- * 求树中的最大值
- * @return
- */
- public Node maxmum() {
- Node current;
- current = root;
- Node last = null;
- while(current != null) {
- last = current;
- current = current.rightChild;
- }
- return last;
- }
下面是完整測试代码:
- package binTree;
- class Node {
- public int iData;
- public double dData;
- public Node leftChild;
- public Node rightChild;
- public void displayNode() {
- System.out.print("{");
- System.out.print(iData);
- System.out.print(",");
- System.out.print(dData);
- System.out.print("}");
- }
- }
- class Tree {
- private Node root;
- public Tree() {
- root = null;
- }
- /**
- * 查找节点
- * @param key
- * @return
- */
- public Node find(int key) {
- // 如果树非空
- Node current = root;
- while(current.iData != key) {
- if(key < current.iData)
- current = current.leftChild;
- else
- current = current.rightChild;
- if(current == null)
- return null;
- }
- return current;
- }
- /**
- * 插入节点
- * @param id
- * @param dd
- */
- public void insert(int id, double dd) {
- Node newNode = new Node();
- newNode.iData = id;
- newNode.dData = dd;
- if(root == null)
- root = newNode;
- else {
- Node current = root;
- Node parent;
- while(true) {
- parent = current;
- if(id < current.iData) {
- current = current.leftChild;
- if(current == null) {
- parent.leftChild = newNode;
- return;
- }
- } else {
- current = current.rightChild;
- if(current == null) {
- parent.rightChild = newNode;
- return;
- }
- }
- } // end while
- } // end else
- }
- /**
- * 前序遍历
- * @param localRoot
- */
- public void preOrder(Node localRoot) {
- if(localRoot != null) {
- System.out.print(localRoot.iData+" ");
- preOrder(localRoot.leftChild);
- preOrder(localRoot.rightChild);
- }
- }
- /**
- * 中序遍历
- * @param localRoot
- */
- public void inOrder(Node localRoot) {
- if(localRoot != null) {
- preOrder(localRoot.leftChild);
- System.out.print(localRoot.iData+" ");
- preOrder(localRoot.rightChild);
- }
- }
- /**
- * 后序遍历
- * @param localRoot
- */
- public void postOrder(Node localRoot) {
- if(localRoot != null) {
- preOrder(localRoot.leftChild);
- preOrder(localRoot.rightChild);
- System.out.print(localRoot.iData+" ");
- }
- }
- /**
- * 求树中的最小值
- * @return
- */
- public Node minimum() {
- Node current;
- current = root;
- Node last = null;
- while(current != null) {
- last = current;
- current = current.leftChild;
- }
- return last;
- }
- /**
- * 求树中的最大值
- * @return
- */
- public Node maxmum() {
- Node current;
- current = root;
- Node last = null;
- while(current != null) {
- last = current;
- current = current.rightChild;
- }
- return last;
- }
- }
- public class TreeApp {
- public static void main(String[] args) {
- Tree theTree = new Tree();
- /**
- * 50
- * / \
- * 25 75
- * / \ \
- * 12 37 87
- * / \ \
- * 30 43 93
- * \ \
- * 33 97
- */
- theTree.insert(50, 1.5);
- theTree.insert(25, 1.2);
- theTree.insert(75, 1.7);
- theTree.insert(12, 1.5);
- theTree.insert(37, 1.2);
- theTree.insert(43, 1.7);
- theTree.insert(30, 1.5);
- theTree.insert(33, 1.2);
- theTree.insert(87, 1.7);
- theTree.insert(93, 1.5);
- theTree.insert(97, 1.5);
- System.out.println("插入完成~");
- //找到root节点
- Node nodeRoot = theTree.find(50);
- // 中序遍历
- theTree.inOrder(nodeRoot);
- System.out.println();
- // 求最小值
- System.out.println("mini:"+ theTree.minimum().iData);
- // 求最大值
- System.out.println("max:"+ theTree.maxmum().iData);
- }
- }
Java对二叉搜索树进行插入、查找、遍历、最大值和最小值的操作的更多相关文章
- Java实现二叉搜索树的插入、删除
前置知识 二叉树的结构 public class TreeNode { int val; TreeNode left; TreeNode right; TreeNode() { } TreeNode( ...
- Java实现二叉搜索树
原创:转载需注明原创地址 https://www.cnblogs.com/fanerwei222/p/11406176.html 尝试一下用Java实现二叉搜索树/二叉查找树,记录自己的学习历程. 1 ...
- 【Java】 剑指offer(33) 二叉搜索树的后序遍历序列
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如 ...
- 剑指Offer:面试题24——二叉搜索树的后序遍历序列(java实现)
问题描述: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则返回true,否则返回false.假设输入的数组的任意两个数字都互不相同. 思路: 1.首先后序遍历的结果是[(左子 ...
- 剑指Offer-23.二叉搜索树的后序遍历序列(C++/Java)
题目: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 分析: 二叉树的后序遍历也就是先访问左子树,再访问右 ...
- 剑指offer23:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。输出Yes OR No。
1 题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 2 思路和方法 二叉搜索树:二叉查找树(Bin ...
- P140、面试题24:二叉搜索树的后序遍历序列
题目:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则返回true,否则返回false.假设输入的数组的任意两个数字都互不相同. 测试用例: 1)功能测试(输入的后序遍历的序列 ...
- [PHP]算法- 判断是否为二叉搜索树的后序遍历序列的PHP实现
二叉搜索树的后序遍历序列: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 思路: 1.后序遍历是 左右中 ...
- 二叉搜索树的后序遍历序列(python)
题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. # -*- coding:utf-8 -*- cl ...
随机推荐
- 微信小程序商品详情 + 评论功能实现
这是一个商品展示并能进行评论和答复的功能页面, 遇到的问题有: 分享功能没有办法将json数据写在地址中,只能传id来进行获取 这里必须新加一个状态用来判断是否显示x回复@x,因为我以前的判断这个依据 ...
- Python基础数据类型(四) tuple元祖
元祖tuple(,) 元祖就是不可变的列表 元祖用()表示,元素与元素之间用逗号隔开,数据类型没有限制 tu = ('科比','詹姆斯','乔丹') tu = tuple('123') 小括号中 有一 ...
- Vue电商SKU组合算法问题
前段时间,公司要做“添加商品”业务模块,这也算是电商业务里面的一个难点了. 令我印象最深的不是什么“组合商品”.“关联商品”.“关联单品”,而是商品SKU的组合问题. 这个问题特别有意思,当时虽然大体 ...
- 【BZOJ3527】[ZJOI2014] 力(FFT)
题目: BZOJ3527 分析: FFT应用第一题-- 首先很明显能把\(F_j\)约掉,变成: \[E_j=\sum _{i<j} \frac{q_i}{(i-j)^2}-\sum_{i> ...
- 【NOIP2016】DAY1 T2 天天爱跑步
[NOIP2016]DAY1 T2 天天爱跑步 Description 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.?天天爱跑步?是一个养成类游戏,需要玩家每天按时 ...
- ACM_百度的面试(单调栈)
百度的面试 Time Limit: 2000/1000ms (Java/Others) Problem Description: 在一个二维平面,从左到右竖立n根高度分别为:a[1],a[2],... ...
- Hadoop Hive概念学习系列之hive里的扩展接口(CLI、Beeline、JDBC)(十六)
<Spark最佳实战 陈欢>写的这本书,关于此知识点,非常好,在94页. hive里的扩展接口,主要包括CLI(控制命令行接口).Beeline和JDBC等方式访问Hive. CLI和B ...
- PHP 在线 编辑 解析
http://www.w3schools.com/php/default.asp http://www.w3schools.com/php/showphp.asp?filename=demo_s ...
- Razor的使用
Razor可以识别尖括号,且关键词是@,默认情况下会对输出的html代码进行转义 1.C#代码 用 @ 加 中括号 包起来 @{ ; i < ; i++) { <h3>C#语句块要用 ...
- T-SQL查询基础
今天来带大家了解下在sql server 中的查询机制 使用select语句进行查询 1.查询所有的数据行和列 select * from student 2.查询部分行和列 select scode ...