文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java排序二叉树怎么定义

2023-06-30 18:36

关注

这篇文章主要介绍了Java排序二叉树怎么定义的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java排序二叉树怎么定义文章都会有所收获,下面我们一起来看看吧。

排序二叉树概念

排序二叉树类的定义

public class binarySortTree {    class Node{        int value;        Node left;        Node right;        public Node(int value){            this.value = value;        }        public void display(){            System.out.print(this.value + " ");        }    }    Node root;}

添加节点

排序二叉树添加节点的十分简单,无论使用递归还是循环,思路都一样,这里我用递归的方式讲解。

  1. 每次添加一个节点时,判断value(添加节点的值)与root的值的大小关系: 若root.value < value, 说明该节点应该添加在root的右子树上。如果右子树为空,直接添加:root.right = new Node(value);如果右子树不为空,那么递归进右子树(令root.right为root)。

  2. root.value >= value, 说明该节点应该添加在root的左子树上。如果左子树为空,直接添加:root.left = new Node(value);如果左子树不为空,那么递归进右子树(令root.left为root)。

代码如下:

//添加节点//此方法可以类内部方法的调用    private void add(Node root,int value){        //添加节点的值大于根节点的值,该节点添加到根节点的右子树上        if(value > root.value){            //根节点的右子树为空,直接添加            if(root.right == null){                root.right = new Node(value);            }            //根节点右子树不为空,递归往右子树插            else{                add(root.right,value);            }        }        //添加节点的值小于或者等于根节点的值,该节点应该添加到左子树        else{            //左子树为空,直接添加            if(root.left == null){                root.left = new Node(value);            }            //左子树不为空,递归往左子树添加            else{                add(root.left, value);            }        }    }    //此方法在类内部和类外部都可以调用    public void add(int value){        //当前树为空树        if(root == null){            root = new Node(value);            return;        }        add(root, value);    }

中序遍历

因为二叉排序树中序遍历的结果就是排序好的,所以这里只提供中序遍历。

代码如下:

//中序遍历树    private  void inPrevOrder(Node root){        if(root == null) return;        inPrevOrder(root.left);        root.display();        inPrevOrder(root.right);    }    public void inPrevOrder(){        System.out.print("中序遍历:");        inPrevOrder(root);    }

查找节点

该方法是查找value在二叉树中对应的位置,是为删除节点提供的方法。

    private Node searchNode(Node root, int value){        //被查找树为null,要查找节点不存在        if(root == null)            return null;        //找到了,返回节点        else if(root.value == value){            return root;        }        //该节点不是要查找节点,继续查找        else{            //该节点的值大于value,往该节点的左子树递归查找            if(root.value > value){                return searchNode(root.left, value);            }            //该节点的值小于value,往该节点的右子树递归查找            else{                return searchNode(root.right, value);            }        }    }

查找某一节点的父节点

该方法是查找二叉树中一个节点的父节点,也是为删除节点提供的方法。

     private Node searchParentNode(Node root, Node node){        //被查找树为null或者根节点就是要查找的节点,那么要查找节点的父节点不存在        if(root == null || root == node){            return null;        }        else if(root.left != null && root.left == node || root.right != null && root.right == node){            return root;        }        else{            if(root.value > node.value){                return searchParentNode(root.left, node);            }            else{                return searchParentNode(root.right, node);            }        }    }

删除节点

删除节点是排序二叉树中最麻烦的方法,因为它有很多种情况。

方法如下:

   第一种情况:删除的节点是叶子节点
(1)需求先去找到要删除的结点targetNode

(2)找到targetNode的父结点parent

(3)确定targetNode是parent的左子结点还是右子结点
   3.1如果targetNode是parent的左子结点:parent.left = null;
   3.2如果targetNode是parent的右子结点:parent.right = null;
   第二种情况:删除只有一颗子树的节点
(1)需求先去找到要删除的结点targetNode

(2)找到targetNode的父结点parent

(3)确定targetNode的子结点是左子结点还是右子结点

(4)确定targetNode是parent的左子结点还是右子结点

(5)如果targetNode有左子结点
   5.1如果targetNode是parent的左子结点parent.left = targetNode.left;
   5.2如果targetNode是parent的右子结点parent.right = targetNode.left;
(6)如果targetNode有右子结点
   6.1如果targetNode是 parent 的左子结点parent.left = targetNode.right;
   6.2如果targetNode是parent 的右子结点parent.right = targetNode.right
    第三种情况:删除的节点有左右两个子树
(1)需求先去找到要删除的结点targetNode

(2)在右子树找到最小的节点,用一个temp保存这个节点的值,然后删除这个最小节点(该最小节点一定是满足第一种情况的)

(3)targetNode.value = temp

除了以上情况,还要考虑要删除的节点就是根节点的情况(此时它的父节点为null),下面会在代码中展示,代码如下:

public void remove(int vlaue){        //找到要删除的节点        Node targetNode = searchNode(root,vlaue);        //要删除节点不存在        if(targetNode == null) return;        //找到要删除节点的父节点        Node targetNodeParent = searchParentNode(root,targetNode);        //要删除节点为叶子节点        if(targetNode.left == null && targetNode.right == null){            //要删除的节点就是根节点            if(targetNodeParent == null){              root = null;            }            else{                //要删除节点是其父节点的左节点                if(targetNodeParent.left == targetNode){                    targetNodeParent.left = null;                }                else{                    targetNodeParent.right = null;                }            }        }        //要删除节点只有一个左子树        else if(targetNode.left != null && targetNode.right == null){            //要删除的节点就是根节点            if(targetNodeParent == null) {                root = root.left;            }            //要删除节点是其父节点的左节点            else if(targetNodeParent.left != null && targetNodeParent.left.value == targetNode.value){                targetNodeParent.left = targetNode.left;            }            //要删除节点是其父节点的右节点            else{                targetNodeParent.right = targetNode.left;            }        }        //要删除节点只有一个右子树        else if(targetNode.right != null && targetNode.left == null){            //要删除的节点就是根节点            if(targetNodeParent == null) {                root = root.right;                return;            }            //要删除节点是其父节点的左节点            else if(targetNodeParent.left != null && targetNodeParent.left.value == targetNode.value){                targetNodeParent.left = targetNode.right;            }            //要删除节点是其父节点的右节点            else{                targetNodeParent.right = targetNode.right;            }        }        //要删除节点右左右都有节点        else{            //找到右子树最小的节点            Node minNode = targetNode.right;            while(minNode.left != null){                minNode = minNode.left;            }            int temp = minNode.value;            //找到右子树上最小节点的父节点            Node minNodeParent = searchParentNode(targetNode.right,minNode);            //右子树根节点就是最小节点            if(minNodeParent == null){                targetNode.right = minNode.right;            }            else{                //要删除节点是其父节点的左节点                minNodeParent.left = minNode.right;            }            targetNode.value = temp;        }    }

关于“Java排序二叉树怎么定义”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Java排序二叉树怎么定义”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯