广告
返回顶部
首页 > 资讯 > 精选 >如何在Java中操作二叉搜索树
  • 225
分享到

如何在Java中操作二叉搜索树

2023-06-15 04:06:38 225人浏览 薄情痞子
摘要

如何在Java中操作二叉搜索树?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、二叉搜索树插入元素     class&n

如何在Java中操作二叉搜索树?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

一、二叉搜索树插入元素

     class node {        int val;        Node left;        Node right;        Node(int val) {            this.val = val;        }    }    public void insert(int key) {        Node node = new Node(key);        if (this.root == null) {            root = node;        }        Node cur = root;        Node parent = null;        while (cur != null) {            if (cur.val == key) {                //System.out.println("元素已经存在");                return;            } else if (cur.val > key) {                parent = cur;                cur = cur.left;            } else {                parent = cur;                cur = cur.right;            }        }        if (key > parent.val) {            parent.right = node;        } else {            parent.left = node;        }    }

二、搜索指定节点

 public boolean search(int key) {        Node cur = root;        while (cur != null) {            if (cur.val == key) {                return true;            } else if (cur.val > key) {                cur = cur.left;            } else {                cur = cur.right;            }        }        return false;    }

三、删除节点方式一

 public void removenode1(Node parent, Node cur) {        if (cur.left == null) {            if (cur == root) {                root = cur.right;            } else if (cur == parent.right) {                parent.left = cur.right;            } else {                parent.right = cur.right;            }        } else if (cur.right == null) {            if (cur == root) {                root.left = cur;            } else if (cur == parent.right) {                parent.right = cur.left;            } else {                parent.left = cur.left;            }        } else {            Node tp = cur;            Node t = cur.right;            while (t.left != null) {                tp = t;                t = t.left;            }            if (tp.left == t) {                cur.val = t.val;                tp.left = t.right;            }            if (tp.right == t) {                cur.val = t.val;                tp.right = t.right;            }        }    }    public void remove(int key) {        Node cur = root;        Node parent = null;        while (cur != null) {            if (cur.val == key) {                removenode1(parent, cur);              //removenode2(parent, cur);                return;            } else if (key > cur.val) {                parent = cur;                cur = cur.right;            } else {                parent = cur;                cur = cur.left;            }        }    }

四、删除节点方式二

 public void removenode2(Node parent, Node cur) {        if (cur.left == null) {            if (cur == root) {                root = cur.right;            } else if (cur == parent.right) {                parent.left = cur.right;            } else {                parent.right = cur.right;            }        } else if (cur.right == null) {            if (cur == root) {                root.left = cur;            } else if (cur == parent.right) {                parent.right = cur.left;            } else {                parent.left = cur.left;            }        } else {            Node tp = cur;            Node t = cur.left;            while (t.right != null) {                tp = t;                t = t.right;            }            if (tp.right == t) {                cur.val = t.val;                tp.right = t.left;            }            if (tp.left == t) {                cur.val = t.val;                tp.left = t.left;            }        }    }

五、运行结果

 class TestBinarySearchTree {    public static void main(String[] args) {        int a[] = {5, 3, 4, 1, 7, 8, 2, 6, 0, 9};        BinarySearchTree binarySearchTree = new BinarySearchTree();        for (int i = 0; i < a.length; i++) {            binarySearchTree.insert(a[i]);        }        binarySearchTree.inOrderTree(binarySearchTree.root);        System.out.println();        binarySearchTree.preOrderTree(binarySearchTree.root);        binarySearchTree.remove(7);        System.out.println();        System.out.println("方法一删除后");        binarySearchTree.inOrderTree(binarySearchTree.root);        System.out.println();        binarySearchTree.preOrderTree(binarySearchTree.root);    }}

如何在Java中操作二叉搜索树
如何在Java中操作二叉搜索树

java基本数据类型有哪些

Java的基本数据类型分为:1、整数类型,用来表示整数的数据类型。2、浮点类型,用来表示小数的数据类型。3、字符类型,字符类型的关键字是“char”。4、布尔类型,是表示逻辑值的基本数据类型。

关于如何在Java中操作二叉搜索树问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: 如何在Java中操作二叉搜索树

本文链接: https://www.lsjlt.com/news/277657.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何在Java中操作二叉搜索树
    如何在Java中操作二叉搜索树?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、二叉搜索树插入元素     class&n...
    99+
    2023-06-15
  • Java基础之二叉搜索树的基本操作
    目录一、二叉搜索树插入元素二、搜索指定节点三、删除节点方式一四、删除节点方式二五、运行结果一、二叉搜索树插入元素 class Node { int v...
    99+
    2022-11-12
  • JavaScript二叉搜索树构建操作详解
    目录前言什么是二叉搜索树构建一颗二叉搜索树二叉搜索树的操作向二叉搜索树中插入数据查找二叉搜索树中的数据删除二叉搜索树的某个节点前驱后继节点删除一个节点的三种情况实现代码完整代码总结前...
    99+
    2022-11-13
  • C++二叉搜索树的操作有哪些
    本文小编为大家详细介绍“C++二叉搜索树的操作有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++二叉搜索树的操作有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。二叉搜索树概念与操作二叉搜索树的概念二...
    99+
    2023-06-29
  • Java中关于二叉树的概念以及搜索二叉树详解
    目录一、二叉树的概念为什么要使用二叉树?树是什么?树的相关术语!根节点路径父节点子节点叶节点子树访问层(深度)关键字满二叉树完全二叉树二叉树的五大性质二、搜索二叉树插入删除hello...
    99+
    2022-11-12
  • Java中如何把二叉搜索树转换为累加树
    这篇文章主要介绍了Java中如何把二叉搜索树转换为累加树,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、题目给出二叉搜索树的根节点,该树的节点值各不相同,请你将其转换为累加...
    99+
    2023-06-25
  • Java创建二叉搜索树,实现搜索,插入,删除的操作实例
    Java实现的二叉搜索树,并实现对该树的搜索,插入,删除操作(合并删除,复制删除)首先我们要有一个编码的思路,大致如下: 1、查找:根据二叉搜索树的数据特点,我们可以根据节点的值得比较来实现查找,查找值大于当前节点时向右走,反之向左走!2、...
    99+
    2023-05-30
    java 二叉搜索树 搜索
  • JavaScript二叉搜索树构建操作实例分析
    本篇内容介绍了“JavaScript二叉搜索树构建操作实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是二叉搜索树二叉搜索树首先它...
    99+
    2023-07-02
  • C++二叉搜索树BSTree如何使用
    这篇文章主要介绍“C++二叉搜索树BSTree如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++二叉搜索树BSTree如何使用”文章能帮助大家解决问题。一、概念二叉搜索树又称二叉排序树,它...
    99+
    2023-07-05
  • 在Java中实现二叉搜索树的全过程记录
    目录二叉搜索树有序符号表的 API实现二叉搜索树二叉搜索树类查找插入最小/大的键小于等于 key 的最大键/大于等于 key 的最小键根据排名获得键根据键获取排名删除总结二叉搜索树 ...
    99+
    2022-11-13
  • Java 求解如何把二叉搜索树转换为累加树
    一、题目 给出二叉搜索树的根节点,该树的节点值各不相同,请你将其转换为累加树(Greater Sum Tree),使每个节点 node 的新值等于原树中大于或等于 node.val ...
    99+
    2022-11-12
  • 如何利用JavaScript实现二叉搜索树
    计算机科学中最常用和讨论最多的数据结构之一是二叉搜索树。这通常是引入的第一个具有非线性插入算法的数据结构。二叉搜索树类似于双链表,每个节点包含一些数据,以及两个指向其他节点的指针;它...
    99+
    2022-11-12
  • C++如何实现验证二叉搜索树
    本文小编为大家详细介绍“C++如何实现验证二叉搜索树”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++如何实现验证二叉搜索树”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。验证二叉搜索树Example 1:In...
    99+
    2023-06-19
  • 如何通过代码实现二叉搜索树
    本篇内容主要讲解“如何通过代码实现二叉搜索树”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何通过代码实现二叉搜索树”吧!首先,二叉搜索树到底是什么二叉搜索树(...
    99+
    2022-10-19
  • C++如何实现LeetCode之复原二叉搜索树
    这篇文章给大家分享的是有关C++如何实现LeetCode之复原二叉搜索树的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。[LeetCode] 99. Recover Binary Search Tree 复原二叉搜...
    99+
    2023-06-20
  • Java如何实现二分搜索树
    这篇文章将为大家详细讲解有关Java如何实现二分搜索树,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.概念a.是个二叉树(每个节点最多有两个子节点)b.对于这棵树中的节点的节点值左子树中的所有节点值 &...
    99+
    2023-06-29
  • 剑指Offer之Java算法习题精讲字符串操作与数组及二叉搜索树
    题目一  解法 class Solution { public String reverseOnlyLetters(String s) { char[]...
    99+
    2022-11-13
  • 如何在Python中创建二叉树
    目录前言二叉树节点定义递归构建二叉树前言 本文的内容是数据结构中二叉树部分最基础的,之所以写一下主要是为了方便刷题的时候,能够在自己电脑上很快的使用这种小的demo进行复杂的练习。...
    99+
    2022-11-12
  • java中如何实现重建二叉树
    题目:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回...
    99+
    2021-06-28
    java教程 java 重建 二叉树
  • C语言中如何利用递归实现线索二叉树
    这篇“C语言中如何利用递归实现线索二叉树”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言中如何利用递归实现线索二叉树”文...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作