iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >java中treemap和treeset实现红黑树
  • 359
分享到

java中treemap和treeset实现红黑树

javatreemaptreeset 2023-05-30 23:05:56 359人浏览 八月长安
摘要

TreeMap 的实现就是红黑树数据结构,也就说是一棵自平衡的排序二叉树,这样就可以保证当需要快速检索指定节点。TreeSet 和 TreeMap 的关系为了让大家了解 TreeMap 和 TreeSet 之间的关系,下面先看 TreeSe

TreeMap 的实现就是红黑树数据结构,也就说是一棵自平衡的排序二叉树,这样就可以保证当需要快速检索指定节点。

TreeSet 和 TreeMap 的关系

为了让大家了解 TreeMap 和 TreeSet 之间的关系,下面先看 TreeSet 类的部分源代码:

 public class TreeSet<E> extends AbstractSet<E>  implements NavigableSet<E>, Cloneable, java.io.Serializable  {  // 使用 NavigableMap 的 key 来保存 Set 集合的元素 private transient NavigableMap<E,Object> m;  // 使用一个 PRESENT 作为 Map 集合的所有 value。 private static final Object PRESENT = new Object();  // 包访问权限的构造器,以指定的 NavigableMap 对象创建 Set 集合 TreeSet(NavigableMap<E,Object> m)  {  this.m = m;  }  public TreeSet()     // ① {  // 以自然排序方式创建一个新的 TreeMap, // 根据该 TreeSet 创建一个 TreeSet, // 使用该 TreeMap 的 key 来保存 Set 集合的元素 this(new TreeMap<E,Object>());  }  public TreeSet(Comparator<? super E> comparator) // ② {  // 以定制排序方式创建一个新的 TreeMap, // 根据该 TreeSet 创建一个 TreeSet, // 使用该 TreeMap 的 key 来保存 Set 集合的元素 this(new TreeMap<E,Object>(comparator));  }  public TreeSet(Collection<? extends E> c)  {  // 调用①号构造器创建一个 TreeSet,底层以 TreeMap 保存集合元素 this();  // 向 TreeSet 中添加 Collection 集合 c 里的所有元素 addAll(c);  }  public TreeSet(SortedSet<E> s)  {  // 调用②号构造器创建一个 TreeSet,底层以 TreeMap 保存集合元素 this(s.comparator());  // 向 TreeSet 中添加 SortedSet 集合 s 里的所有元素 addAll(s);  }  //TreeSet 的其他方法都只是直接调用 TreeMap 的方法来提供实现 ...  public boolean addAll(Collection<? extends E> c)  {  if (m.size() == 0 && c.size() > 0 &&   c instanceof SortedSet &&   m instanceof TreeMap)  {   // 把 c 集合强制转换为 SortedSet 集合  SortedSet<? extends E> set = (SortedSet<? extends E>) c;   // 把 m 集合强制转换为 TreeMap 集合  TreeMap<E,Object> map = (TreeMap<E, Object>) m;   Comparator<? super E> cc = (Comparator<? super E>) set.comparator();   Comparator<? super E> mc = map.comparator();   // 如果 cc 和 mc 两个 Comparator 相等  if (cc == mc || (cc != null && cc.equals(mc)))   {   // 把 Collection 中所有元素添加成 TreeMap 集合的 key   map.addAllForTreeSet(set, PRESENT);   return true;   }  }  // 直接调用父类的 addAll() 方法来实现 return super.addAll(c);  }  ...  } 

--结束END--

本文标题: java中treemap和treeset实现红黑树

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

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

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

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

下载Word文档
猜你喜欢
  • java中treemap和treeset实现红黑树
    TreeMap 的实现就是红黑树数据结构,也就说是一棵自平衡的排序二叉树,这样就可以保证当需要快速检索指定节点。TreeSet 和 TreeMap 的关系为了让大家了解 TreeMap 和 TreeSet 之间的关系,下面先看 TreeSe...
    99+
    2023-05-30
    java treemap treeset
  • 利用Java实现红黑树
    目录1、红黑树的属性2、旋转3、插入4、删除5、所有代码6、演示1、红黑树的属性 红黑树是一种二分查找树,与普通的二分查找树不同的一点是,红黑树的每个节点都有一个颜色(color)属...
    99+
    2024-04-02
  • java算法如何实现红黑树
    这篇文章主要介绍了java算法如何实现红黑树,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。红黑树定义红黑树(英语:Red–black tree)是一种自平衡二叉查找树,是在计...
    99+
    2023-05-30
    java
  • HashMap红黑树入门(实现一个简单的红黑树)
    目录1.树结构入门1.1 什么是树?1.2 树结构常用术语1.3 二叉搜索树2.红黑树原理讲解2.1 红黑树的性质:2.2 红黑树案例分析3.手写红黑树4. HashMap底层的红黑...
    99+
    2024-04-02
  • java实现红黑树的代码怎么写
    本篇内容介绍了“java实现红黑树的代码怎么写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 红黑树ja...
    99+
    2024-04-02
  • Java实现红黑树(平衡二叉树)的详细过程
    目录前言红黑二叉查找树2-3树2-3树的插入操作实现红黑二叉树结尾前言 在实现红黑树之前,我们先来了解一下符号表。 符号表的描述借鉴了Algorithms第四版,详情在:https...
    99+
    2024-04-02
  • 红黑树的实现原理是什么
    本篇文章给大家分享的是有关红黑树的实现原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、摘要平衡二叉查找树是一个高度平衡的二叉树,也...
    99+
    2024-04-02
  • C++ RBTree红黑树的性质与实现
    目录一、红黑树的概念二、红黑树的性质三、红黑树节点的定义四、红黑树的插入五、代码实现一、红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点上增加一个存储位表示结点的颜色,可以是Re...
    99+
    2023-03-08
    C++ RBTree红黑树 C++ RBTree C++ 红黑树
  • Java数据结构之红黑树的原理及实现
    目录为什么要有红黑树这种数据结构红黑树的简介红黑树的基本操作之旋转红黑树之添加元素红黑树之删除结点删除结点没有儿子的情况删除结点仅有一个儿子结点的情况删除结点有两个儿子结点红黑树动态...
    99+
    2024-04-02
  • C++实现红黑树应用实例代码
    红黑树的应用: 1、利用key_value对,快速查找,O(logn) socket与客户端id之间,形成映射关系(socket, id) 内存分配管理 ...
    99+
    2024-04-02
  • C++详细实现红黑树流程详解
    目录红黑树的概念红黑树的性质红黑树的定义与树结构插入新增结点插入后维护红黑树性质的主逻辑旋转验证红黑树与AVl树的比较红黑树的应用红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点...
    99+
    2024-04-02
  • C++数据结构之红黑树的实现
    目录一、什么是红黑树二、红黑树的约定三、红黑树vsAVL四、红黑树的实现1.找到插入的位置2.控制平衡3.测试代码五、完整代码1.test.c2.RBTree.h一、什么是红黑树 红...
    99+
    2022-11-13
    C++ 数据结构 红黑树 C++ 红黑树
  • C语言实现红黑树详细步骤+代码
    目录红黑树的概念红黑树的性质红黑树的定义与树结构插入新增结点插入后维护红黑树性质的主逻辑拆解讨论:旋转验证红黑树与AVl树的比较红黑树的应用总结红黑树的概念 红黑树,是一种二叉搜索树...
    99+
    2024-04-02
  • C语言实现手写红黑树的示例代码
    目录前沿红黑树代码测试前沿 写C的红黑树前建议先看我博客这篇文章Java-红黑树 主要看原理 红黑树代码 #ifndef STUDY_RBTREE_H #define ...
    99+
    2024-04-02
  • 为何Redis使用跳表而非红黑树实现SortedSet
    目录什么是跳表跳表的意义究竟在于何处?跳表的搜索时间复杂度跳表是不是很费内存?插入和删除的时间复杂度插入删除跳表索引动态更新跳表的代码实现(Java 版)数据结构定义搜索算法插入和删...
    99+
    2024-04-02
  • 基于红黑树插入操作原理及java实现的示例分析
    这篇文章主要介绍基于红黑树插入操作原理及java实现的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!红黑树是一种二叉平衡查找树,每个结点上有一个存储位来表示结点的颜色,可以是RED或BLACK。红黑树具有以下...
    99+
    2023-05-30
    java
  • C++ STL容器详解之红黑树部分模拟实现
    目录一、红黑树的概念二、红黑树的性质三、红黑树节点的定义四、红黑树结构 五、 红黑树的插入操作六、代码总结一、红黑树的概念 红黑树(Red Black Tree),是在计算机科学中用...
    99+
    2024-04-02
  • C++ RBTree红黑树的性质与实现方法是什么
    这篇文章主要讲解了“C++ RBTree红黑树的性质与实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++ RBTree红黑树的性质与实现方法是什么”吧!一...
    99+
    2023-07-05
  • 红黑树的原理及特点及其在Python中的代码实现
    红黑树和B+树一样,是平衡二叉搜索树。红黑树每个节点都是有颜色的,要么是红色,要么黑色,但树的根是黑色,最底部的叶也是黑色的。还需要注意的是,红黑树任何节点到叶的直接路径包含相同数量的黑色节点。 红黑树如何保持自平衡的特性? ...
    99+
    2024-01-23
  • C++ STL容器中红黑树部分模拟实现的示例分析
    这篇文章主要介绍了C++ STL容器中红黑树部分模拟实现的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、红黑树的概念红黑树(Red Black Tree...
    99+
    2023-06-21
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作