iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在java项目中实现一个二叉查找树算法
  • 860
分享到

怎么在java项目中实现一个二叉查找树算法

java二叉查找树ava 2023-05-31 08:05:23 860人浏览 八月长安
摘要

今天就跟大家聊聊有关怎么在java项目中实现一个二叉查找树算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体内容如下package 查找;import edu

今天就跟大家聊聊有关怎么在java项目中实现一个二叉查找树算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

具体内容如下

package 查找;import edu.princeton.cs.algs4.Queue;import edu.princeton.cs.algs4.StdOut;public class BST<Key extends Comparable<Key>, Value> {  private class node {    private Key key; // 键    private Value value;// 值    private Node left, right; // 指向子树的链接    private int n; // 以该节点为根的子树中的节点总数    public Node(Key key, Value val, int n) {      this.key = key;      this.value = val;      this.n = n;    }  }  private Node root;  public int size() {    return size(root);  }  private int size(Node x) {    if (x == null)      return 0;    else      return x.n;  }    public Value get(Key key) {    return get(root, key);  }  private Value get(Node x, Key key) {    if (x == null)      return null;    int cmp = key.compareTo(x.key);    if (cmp < 0)      return get(x.left, key);    else if (cmp > 0)      return get(x.right, key);    else      return x.value;  }    public void put(Key key, Value val) {    root = put(root, key, val);  }  private Node put(Node x, Key key, Value val) {    if (x == null)      return new Node(key, val, 1);    int cmp = key.compareTo(x.key);    if (cmp < 0)      x.left = put(x.left, key, val);    else if (cmp > 0)      x.right = put(x.right, key, val);    else      x.value = val;    x.n = size(x.left) + size(x.right); // 要及时更新节点的子树数量    return x;  }  public Key min() {    return min(root).key;  }  private Node min(Node x) {    if (x.left == null)      return x;    return min(x.left);  }  public Key max() {    return max(root).key;  }  private Node max(Node x) {    if (x.right == null)      return x;    return min(x.right);  }    public Key floor(Key key) {    Node x = floor(root, key);    if (x == null)      return null;    else      return x.key;  }    private Node floor(Node x, Key key) {    if (x == null)      return null;    int cmp = key.compareTo(x.key);    if (cmp == 0)      return x;    else if (cmp < 0)      return floor(x.left, key);    else {      Node t = floor(x.right, key);      if (t == null)        return x;      else        return t;    }  }    public Key ceiling(Key key) {    Node x = ceiling(root, key);    if (x == null)      return null;    else      return x.key;  }    private Node ceiling(Node x, Key key) {    if (x == null)      return null;    int cmp = key.compareTo(x.key);    if (cmp == 0)      return x;    else if (cmp > 0) {      return ceiling(x.right, key);    } else {      Node t = floor(x.left, key);      if (t == null)        return x;      else        return t;    }  }    public Key select(int k) {    return select(root, k).key;  }  private Node select(Node x, int k) {    if (x == null)      return null;    int t = size(x.left);    if (t > k)      return select(x.left, k);    else if (t < k)      return select(x.right, k - t - 1);// 根节点也要排除掉    else      return x;  }    public int rank(Key key) {    return rank(key, root);  }  private int rank(Key key, Node x) {    if (x == null)      return 0;    int cmp = key.compareTo(x.key);    if (cmp < 0)      return rank(key, x.left);    else if (cmp > 0)      return 1 + size(x.left) + rank(key, x.right);    else      return size(x.left);  }    public void deleteMin(){    root = deleteMin(root);  }    private Node deleteMin(Node x){    if(x.left == null) return x.right;    x.left = deleteMin(x.left);    x.n = size(x.left)+size(x.right) + 1;    return x;  }    public void deleteMax(){    root = deleteMax(root);  }  private Node deleteMax(Node x){    if(x.right == null ) return x.left;    x.right = deleteMax(x.right);    x.n = size(x.left)+size(x.right) + 1;    return x;  }    public void delete(Key key){    root = delete(root,key);  }  private Node delete(Node x, Key key){    if(x == null) return null;    int cmp = key.compareTo(x.key);    if(cmp < 0) x.left = delete(x.left,key);    else if(cmp > 0) x.right = delete(x.right,key);    else{      if(x.right == null) return x.left;      if(x.left == null ) return x.right;            Node t = x;      x = min(t.right);      x.left = t.left;      x.right = deleteMin(t.right);    }    x.n = size(x.left) + size(x.right) +1;    return x;  }    public void print(){    print(root);  }  private void print(Node x){    if(x == null ) return;    print(x.left);    StdOut.println(x.key);    print(x.right);  }    public Iterable<Key> keys(){    return keys(min(),max());  }  public Iterable<Key> keys(Key lo, Key hi){    Queue<Key> queue = new Queue<Key>();    keys(root, queue, lo, hi);    return queue;  }  private void keys(Node x, Queue<Key> queue, Key lo, Key hi){    if(x == null) return;    int cmplo = lo.compareTo(x.key);    int cmphi = lo.compareTo(x.key);    if(cmplo < 0 ) keys(x.left,queue,lo,hi);    if(cmplo <= 0 && cmphi >= 0) queue.enqueue(x.key);    if(cmphi > 0 ) keys(x.right,queue,lo,hi);  }}

看完上述内容,你们对怎么在java项目中实现一个二叉查找树算法有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网精选频道,感谢大家的支持。

--结束END--

本文标题: 怎么在java项目中实现一个二叉查找树算法

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

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

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

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

下载Word文档
猜你喜欢
  • 怎么在java项目中实现一个二叉查找树算法
    今天就跟大家聊聊有关怎么在java项目中实现一个二叉查找树算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体内容如下package 查找;import edu...
    99+
    2023-05-31
    java 二叉查找树 ava
  • 怎么在Java中利用二叉查找树算法实现一个排序功能
    这期内容当中小编将会给大家带来有关怎么在Java中利用二叉查找树算法实现一个排序功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。具体如下:public class BinaryNode<T ext...
    99+
    2023-05-31
    java 二叉查找树 排序
  • JavaScript 中怎么实现一个二叉树算法
    这篇文章将为大家详细讲解有关JavaScript 中怎么实现一个二叉树算法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。二叉树和二叉搜索树介绍二叉树中的节点...
    99+
    2024-04-02
  • 怎么在Java中实现一个二叉树路径
    这篇文章给大家介绍怎么在Java中实现一个二叉树路径,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。给定一个二叉树,和 目标值 = 5:  1 / \ 2 4&...
    99+
    2023-05-30
    java
  • C#中怎么实现一个二叉树遍历算法
    这篇文章给大家介绍C#中怎么实现一个二叉树遍历算法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。C#算法实现了二叉树的定义,怎么构造一颗已知的二叉树,用几种常规的算法(先序,中序,后序,层次)进行C#二叉树遍历。希望能...
    99+
    2023-06-18
  • 如何在Java项目中实现一个快速查找算法
    如何在Java项目中实现一个快速查找算法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。快速查找算法,可以根据想要找的是第几个大的数,每次循环都能固定下来一个数在数组完整排完序之...
    99+
    2023-05-31
    java ava 目中
  • Java怎么实现二叉查找树的增删查
    本篇内容介绍了“Java怎么实现二叉查找树的增删查”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!定义二叉查找树(ADT)是一个具有对于树种的...
    99+
    2023-07-02
  • C语言中二叉查找树怎么实现
    本文小编为大家详细介绍“C语言中二叉查找树怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言中二叉查找树怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。二叉查找树性质1、二叉树每个树的节点最多有...
    99+
    2023-06-16
  • 怎么在C++项目中遍历二叉树
    怎么在C++项目中遍历二叉树?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在讲遍历之前,我们要先创建一个树:#include <iostream>us...
    99+
    2023-06-08
  • 怎么在java项目中实现一个海盗算法
    今天就跟大家聊聊有关怎么在java项目中实现一个海盗算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体方法如下:package unit4;public cl...
    99+
    2023-05-31
    java 海盗算法 ava
  • 怎么在Java项目中实现一个堆排序算法
    怎么在Java项目中实现一个堆排序算法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。堆是数据结构中的一种重要结构,了解“堆”的概念和操作,可以帮助我们快速地掌握堆排序。堆的...
    99+
    2023-05-31
    java 堆排序算法 ava
  • 怎么在Python中创建一个二叉树
    这篇文章将为大家详细讲解有关怎么在Python中创建一个二叉树,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。二叉树节点定义二叉树的节点定义如下:class TreeNode():#...
    99+
    2023-06-14
  • 怎么在Java项目中实现一个求逆矩阵算法
    这篇文章给大家介绍怎么在Java项目中实现一个求逆矩阵算法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。实现方法如下:package demo;public class MatrixInverse { public ...
    99+
    2023-05-31
    java 求逆矩阵算法 ava
  • 在java项目中实现一个树形选择排序
    在java项目中实现一个树形选择排序?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。树形选择排序:又称锦标赛排序(Tournament Sort),是一种按照锦标赛的思想进行选择...
    99+
    2023-05-31
    java 树形选择排序 ava
  • 快速查找与二分查找算法如何在Java中实现
    这期内容当中小编将会给大家带来有关快速查找与二分查找算法如何在Java中实现,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1. 快速查找:这个是相当简单的,以数组举例,就用一个for循环去查找数组中需要查...
    99+
    2023-05-31
    java 快速查找 二分查找
  • JavaScript中二叉树如何实现查找最小值、最大值、给定值算法
    小编给大家分享一下JavaScript中二叉树如何实现查找最小值、最大值、给定值算法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体如下:function Node(data,...
    99+
    2024-04-02
  • 使用JavaScript怎么实现一个二叉搜索树
    今天就跟大家聊聊有关使用JavaScript怎么实现一个二叉搜索树,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点...
    99+
    2023-06-07
  • 在java项目中实现一个冒泡排算法的方法
    这期内容当中小编将会给大家带来有关在java项目中实现一个冒泡排算法的方法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、算法原理比较相邻的元素。如果第一个比第二个大,就交换他们两个。对每一对相邻元素作...
    99+
    2023-05-31
    java 冒泡排序 ava
  • 如何在Java项目中实现一个DES加密算法
    如何在Java项目中实现一个DES加密算法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Base64.javapackage com.mstf.des; import java...
    99+
    2023-05-31
    des加密 java
  • C++高级数据结构之二叉查找树怎么实现
    本文小编为大家详细介绍“C++高级数据结构之二叉查找树怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++高级数据结构之二叉查找树怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。高级数据结构(Ⅳ)...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作