//二叉树系统
public class BinarySystem {
public static void main(String[] args) {
BinaryDomain root = null; //定义头结点
new BinaryAction().manage(root);
}
}
public class BinaryDomain {
private int value; //二叉树值
BinaryDomain left; //左结点
BinaryDomain right; //右结点
public int getValue() {
return value;
}
public void setValue(int value) {
this.value = value;
}
public BinaryDomain() {
super();
// TODO Auto-generated constructor stub
}
public BinaryDomain(int value) {
super();
this.value = value;
}
}
public interface BinaryBean {
public void manage(BinaryDomain root); //二叉树管理
public BinaryDomain add(BinaryDomain root); //二叉树增加
public BinaryDomain delete(BinaryDomain root); //二叉树删除
public void query(BinaryDomain root); //二叉树查询
public void update(BinaryDomain root); //二叉树修改
}

import java.util.Scanner;

public class BinaryAction implements BinaryBean{

	private Scanner input = new Scanner(System.in);
@Override
public void manage(BinaryDomain root) {
while (true) {
System.out.println("①增加 ②删除 ③查询 ④修改 ⑤返回");
int select = input.nextInt();
if (select == 1) {
root = add(root);
} else if (select == 2) {
root = delete(root);
} else if (select == 3) {
query(root);
} else if (select == 4) {
update(root);
} else {
break;
}
}
} //增加
@Override
public BinaryDomain add(BinaryDomain root) {
System.out.println("请输入需要增加的值: ");
int value = input.nextInt();
if (value < 0) {
System.out.println("输入的值不合法");
} else {
BinaryDomain binary = new BinaryDomain(value); //将值存入对象
if (root == null) { //头为空
root = binary; //将值给头
System.out.println("二叉树的头结点增加成功");
} else {
BinaryDomain temp = root; //将头保护起来
while (temp != null) {
//小左大右
if (binary.getValue() > temp.getValue()) {
//要增加的值大于当前头的值
if (temp.right == null) {
temp.right = binary;
System.out.println("添加右子树值成功");
break;
} else {
temp = temp.right;
}
} else if (binary.getValue() < temp.getValue()){
//要增加的值小于当前头的值
if (temp.left == null) {
temp.left = binary;
System.out.println("添加左子树值成功");
break;
} else {
temp = temp.left;
}
} else {
//要增加的值等于当前头的值
System.out.println("要增加的数值已存在,增加数据失败");
break;
}
}
}
}
return root;
} //删除
@Override
public BinaryDomain delete(BinaryDomain root) {
BinaryDomain temp = root; //保护头结点
BinaryDomain tempPre = null; //要删除的前一个结点
BinaryDomain del = null; //记录要删除的结点
System.out.println("请输入需要删除的值: ");
int value = input.nextInt();
while (temp != null) {
if (temp.getValue() == value) {
//当前结点值 == 要删除的值
del = temp; //记录要删除的结点
break;
} else if (temp.getValue() > value) {
//当前结点值 > 要删除的值 往左移至下一个
tempPre = temp; //记录要删除结点的前一个结点
temp = temp.left;
} else {
//当前结点值 < 要删除的值 往右移至下一个
tempPre = temp;
temp = temp.right;
}
}
//判断要删除的结点是否为头结点
if (del != null && tempPre == null) {
System.out.println("要删除的为头结点");
if (del.left == null && del.right == null) {
//头结点 无左无右
root = null;
System.out.println("删除 无左无右 头结点成功");
} else if (del.left != null && del.right == null) {
//要删除的头结点 有左无右
root = del.left;
System.out.println("删除 有左无右 头结点成功");
} else if (del.left == null && del.right != null) {
//要删除的头结点 无左有右
root = del.right;
System.out.println("删除 无左有右 头结点成功");
} else {
//要删除的头结点 有左有右
System.out.println("要删除的头结点有左有右: ①上移左边的最右边结点值 ②上移右边的最左边结点值");
int option = input.nextInt();
if (option == 1) {
//移左边的最右边结点的值
BinaryDomain delLeft = del.left; //用一个对象指向要删除结点的左边
if (delLeft.right == null && delLeft.left == null) {
//如果要删除的结点的左边结点没有子结点,则把要删除的结点值等于delLeft值,需要删除结点的左结点为空
del.setValue(delLeft.getValue());
del.left = null;
System.out.println("删除 有左有右 头结点成功,头结点的左子树下 无子树");
} else if (delLeft.right == null && delLeft.left != null) {
//要删除的结点的左边结点 有左子树无右子树
del.setValue(delLeft.getValue());
del.left = delLeft.left;
System.out.println("删除 有左有右 头结点成功,头结点的左子树下 有左子树无右子树");
} else {
//要删除的结点的左边结点有右子树
BinaryDomain movePre = null; //记录删除结点左边结点的需要移走的最右边的结点的父结点
while (delLeft.right != null) {
movePre = delLeft;
delLeft = delLeft.right;
}
del.setValue(delLeft.getValue());
movePre.right = delLeft.left;
System.out.println("删除 有左有右 头结点成功,头结点的左子树下 有右子树 需要移动");
}
} else {
//移右边的最左边结点值
BinaryDomain delRight = del.right; //用一个对象指向要删除结点的右边
if (delRight.right == null && delRight.left == null) {
//如果要删除的结点的右边结点没有子结点,则把要删除的结点值等于delRight值,需要删除结点的右结点为空
del.setValue(delRight.getValue());
del.right = null;
System.out.println("删除 有左有右 头结点成功,头结点的右子树下 无子树");
} else if (delRight.right != null && delRight.left == null) {
//要删除的结点的右边结点 有右子树无左子树
del.setValue(delRight.getValue());
del.right = delRight.right;
System.out.println("删除 有左有右 头结点成功,头结点的右子树下 有右子树无左子树");
} else {
//要删除的结点的右边结点有左子树
BinaryDomain movePre = null; //记录删除结点右边结点的需要移走的最左边的结点的父结点
while (delRight.left != null) {
movePre = delRight;
delRight = delRight.left;
System.out.println("删除 有左有右 头结点成功,头结点的右子树下 有左子树 需要移动");
}
}
}
}
} else {
//要删除的不是头结点
if (del.left == null && del.right == null) {
//要删除的结点无左无右 为叶子结点
System.out.println("需要删除的为叶子结点");
if (del.getValue() > tempPre.getValue()) {
//要删除的值大于父结点的值 删除的为右叶子结点
tempPre.right = null;
System.out.println("删除非根结点下的右叶子结点成功");
} else {
//要删除的值小于父结点的值 删除的为左叶子结点
temp.left = null;
System.out.println("删除非根结点下的左叶子结点成功");
}
} else if (del.left == null && del.right != null) {
//要删除的结点无左有右
if (del.getValue() > tempPre.getValue()) {
//要删除的值大于父结点的值 要删除的为父结点下的右子树
tempPre.right = del.right;
System.out.println("删除非根结点下的右子树成功,且该右子树下 有右子树无左子树");
} else {
//要删除的值小于父结点的值 要删除的为父结点下的左子树
tempPre.left = del.right;
System.out.println("删除非根结点下的左子树成功,且该左子树下 有右子树无左子树");
}
} else if (del.left != null && del.right == null) {
//要删除的结点有左无右
if (del.getValue() > tempPre.getValue()) {
//要删除的值大于父结点的值 要删除的为父结点下的右子树
tempPre.right = del.left;
System.out.println("删除非根结点下的右子树成功,且该右子树下 有左子树无右子树");
} else {
//要删除的值小于父结点的值 要删除的为父结点下的左子树
tempPre.left = del.left;
System.out.println("删除非根结点下的左子树成功,且该左子树下 有左子树无右子树");
}
}else {
//要删除的结点有左有右
System.out.println("要删除的结点有左有右: ①上移左边的最右边结点值 ②上移右边的最左边结点值");
int option = input.nextInt();
if (option == 1) {
//移左边的最右边结点
BinaryDomain delLeft = del.left; //定义对象指向要删除结点的左边结点
if (delLeft.right == null && delLeft.left == null) {
//要删除结点的左边结点 无左子树无右子树
del.setValue(delLeft.getValue());
del.left = null;
System.out.println("删除非根结点下左子树成功,且该左子树下 无左子树无右子树");
} else if (delLeft.right == null && delLeft.left != null) {
//要删除结点的左边结点 有左子树无右子树
del.setValue(delLeft.getValue());
del.left = delLeft.left;
System.out.println("删除非根结点下左子树成功,且该左子树下 有左子树无右子树");
} else {
//要删除结点的左边结点 无左子树有右子树
BinaryDomain movePre = null; //记录删除结点左边结点的需要移走的最右边的结点的父结点
while (delLeft.right != null) {
movePre = delLeft;
delLeft = delLeft.right;
}
del.setValue(delLeft.getValue());
movePre.right = delLeft.left;
System.out.println("删除非根结点下左子树成功,且该左子树下 有右子树 需要移动");
}
} else {
//移右边的最左边结点
BinaryDomain delRight = del.right; //定义对象指向要删除结点的右结点
if (delRight.right == null && delRight.left == null) {
//要删除结点的右子树下无子树
del.setValue(delRight.getValue());
del.right = null;
System.out.println("删除非根结点下右子树成功,且该右子树下 无子树");
} else if (delRight.right != null && delRight.left == null) {
//要删除结点的右子树下有右子树无左子树
del.setValue(delRight.getValue());
del.right = delRight.right;
System.out.println("删除非根结点下右子树成功,且该右子树下 无左子树有右子树");
} else {
//要删除结点的右子树下有左子树
BinaryDomain movePre = null; //记录删除结点右边结点的需要移走的最左边的结点的父结点
while (delRight.left != null) {
movePre = delRight;
delRight = delRight.left;
}
del.setValue(delRight.getValue());
movePre.left = del.right;
System.out.println("删除非根结点下右子树成功,且该右子树下 有左子树 需要移动");
}
}
}
}
return root;
} //查询
@Override
public void query(BinaryDomain root) {
System.out.println("①先序查询 ②中序查询 ③后序查询");
int select = input.nextInt();
if (select == 1) {
//先序查询 根 左 右
preorder(root);
} else if (select == 2) {
//中序查询 左 根 右
inorder(root);
} else {
//后序查询 左 右 根
epilogue(root);
}
} //先序查询 根 左 右
public void preorder(BinaryDomain root) {
BinaryDomain temp = root;
if (temp != null) {
System.out.println("先序查询为: "+temp.getValue()); //根
preorder(temp.left); //左
preorder(temp.right); //右
}
} //中序查询 左 根 右
public void inorder (BinaryDomain root) {
BinaryDomain temp = root;
if (temp != null) {
inorder(temp.left); //左
System.out.println("中序查询为: "+temp.getValue()); //根
inorder(temp.right); //右
}
} //后序查询 左 右 根
public void epilogue (BinaryDomain root) {
BinaryDomain temp = root;
if (temp != null) {
epilogue (temp.left); //左
epilogue (temp.right); //右
System.out.println("后序查询为: "+temp.getValue()); //根
}
} //修改
@Override
public void update(BinaryDomain root) {
System.out.println("请输入需要修改的数据元素: ");
int update = input.nextInt();
}
}

修改没写了 ,很麻烦 ,如有需要留言,告诉你具体实现思路。。

Java数据结构——二叉树 增加、删除、查询的更多相关文章

  1. (2)Java数据结构--二叉树 -和排序算法实现

    === 注释:此人博客对很多个数据结构类都有讲解-并加以实例 Java API —— ArrayList类 & Vector类 & LinkList类Java API —— BigDe ...

  2. java数据结构——二叉树(BinaryTree)

    前面我们已经学习了一些线性结构的数据结构和算法,接下来我们开始学习非线性结构的内容. 二叉树 前面显示增.删.查.遍历方法,完整代码在最后面. /** * 为什么我们要学习树结构. * 1.有序数组插 ...

  3. Java数据结构——二叉树

    前序遍历——根 左 右 中序遍历——左 根 右 后序遍历——左 右 根 //================================================= // File Name ...

  4. 树——平衡二叉树插入和查找的JAVA实现(2):增加删除方法

    package com.tomsnail.data.tree; /** * AVL二叉平衡树 * @author tomsnail * @date 2015年3月30日 下午4:35:50 */ pu ...

  5. iptables中增加/删除/查询/修改的基本操作

    虽然在Ubuntu使用了UFW来简化iptables的操作,但是UFW只针对防火墙方面,转发方面没有涉及,所以要弄懂其中的原理,还是必须回归到iptables中.CentOS也是如此.下面是针对ipt ...

  6. Java数据结构——二叉树的遍历(汇总)

    二叉树的遍历分为深度优先遍历(DFS)和广度优先遍历(BFS) DFS遍历主要有: 前序遍历 中序遍历 后序遍历 一.递归实现DFSNode.java: public class Node { pri ...

  7. Java数据结构——二叉树节点的增删改查、获取深度及最大最小值

    一.查找最大值 // 查找最大值 public static Node maxNode() { Node node = root; Node maxNode = node; while (node ! ...

  8. java数据结构(二叉树)

    Node节点: public class Node { public long data; public String sData; public Node leftChild; public Nod ...

  9. Java数据结构和算法(四)赫夫曼树

    Java数据结构和算法(四)赫夫曼树 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 赫夫曼树又称为最优二叉树,赫夫曼树的一个 ...

随机推荐

  1. TerraBuilder创建地形之去除影像黑边,填充影像

    最近在Skyline项目中使用TerraBuilder创建地形,由于地形比较大,分块下载卫星影像,然后再TerraBuilder中合并,由于合并.图形等等问题,导致创建处理出来的地形中存在严重的缝隙和 ...

  2. Ubuntu通过xinput禁用及启用联想笔记本的触摸板

    查看设备列表 通过xinput先查看一些都有哪些设备 xinput     #或者 xinput list 显示结果如下 ddd@ddd:~$ xinput list   Virtual core p ...

  3. 在 Flask 应用中使用 gevent

    在 Flask 应用中使用 gevent 普通的 flask 应用 通常在用 python 开发 Flask web 应用时,使用 Flask 自带的调试模式能够给开发带来极大便利.Flask 自带的 ...

  4. 安装VMware,出现Microsoft Runtime DLL 安装程序未能完成安装,解决方法

    安装VMware Workstation 12 Player出现如下问题: 解决方法: 1.出现这个问题的时候不要点确定(如果点了确定,会找不到步骤4中的文件夹) 2.win+R调出 '运行' 3.输 ...

  5. 使用ANY、Some或All关键字

    可以使用All或Any关键字修改引入子查询的比较运算符.Some是与Any等效的ISO标准,All要求Where表达式与子查询返回的每个值进行比较时都应满足比较条件,Any则要求Where表达式与子查 ...

  6. Javaweb三大组件-过滤器、监听器

    1. 过滤器 [filter] 作用: 对单个获取多个servlet起到增强[advice]的作用. 用于在所有的servlet执行前,做一些预处理.例如:做编码处理, 访问量统计[servletCo ...

  7. MySQL出现时区错误的解决方法

    目录 环境 问题 分析 解决方法 环境 windows10 MySQL 8.0.13 IDEA 问题 The server time zone value 'Öйú±ê׼ʱ¼ä' is unre ...

  8. laravel vue.js的使用

    安装cors    地址:https://github.com/barryvdh/laravel-cors 在Kernel文件中加上 protected $middleware = [ \Barryv ...

  9. 编程语言的发展历史剧。(参考https://baijiahao.baidu.com/s?id=1588675986991787716&wfr=spider&for=pc)

    1800年 约瑟夫·玛丽·雅卡尔(Joseph Marie Jacquard),设计出人类历史 上首台可设计织布机——雅卡尔织布机,对将来发展出其他可编程机器起了重要作用 1842年 阿达·洛夫莱斯( ...

  10. ActiveMQ VirtualTopic

    参考网址: http://activemq.apache.org/virtual-destinations.html http://blog.csdn.net/kimmking/article/det ...