热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

详解红黑树和TreeMap的方法原理

参考算法导论本文篇幅可能较长需要读者慢慢理解,一步一步看。什么是红黑树?我们要了解红黑树就必须知道红黑树是什么?红黑树的红和黑是什么意思?红黑树能

       参考算法导论  本文篇幅可能较长需要读者慢慢理解,一步一步看。

       什么是红黑树?

       我们要了解红黑树就必须知道红黑树是什么?红黑树的红和黑是什么意思?红黑树能解决什么样的问题?红黑树解决这样问题采用的是什么方法?如果带着这样的问题去了解红黑树那么就有助于我们清楚的认识红黑树。

      首先对二叉树进行讲解(了解二叉树的同学可以跳过)

      首先二叉树这种数据结构是为了解决数据进行检索时快速的找到我们要找的数据。它区别于链表在于检索数据时所付出的时间代价是不一样的。

        

              从上图我们可以清楚的了解什么样的数据选择什么样的结构。比如我们要在集合{1,2,3,4····10000}中查找整数n,那么链表最坏的情况下的时间复杂度为O(n),而二叉树(二叉树建立的合理矮胖矮胖的)则只需要O(lg n)。而数据量越来越大时二叉树表现得越好。

            但是当二叉树的数据分布是这个样子时那它和链表的区别就很小了。

            

            这样的二叉树结构显然不是我们想要的,我们想要的是那种深度越小越好的,也就是矮矮胖胖的。

           平衡二叉树

           平衡二叉树通过在给元素插入时改变节点数据来使树的结构变得矮平。

           

             从b变为a就是平衡二叉树的作用。

             那么平衡二叉树和红黑树有什么关系呢?红黑树就是一种平衡二叉树,它是通过改变元素节点时通过左旋和右旋进行的。那么还是倒回来,红是啥?黑是啥?左旋是啥?右旋是啥?这都tm是啥?哈哈。要想了解就要了解红黑树相关的另一种2-3树,红黑树是通过2-3树演化而来。

           2-3平衡树

           首先我们看一看2-3-4平衡树的结构。

           

            其中

                  根节点5是一个2-节点   2-节点就是有一个元素和两个儿子

                  子节点7 9是一个3-节点  3-节点就是有两个元素和三个儿子

                  子节点10  11  12 是一个4-节点 4-节点就是有三个元素四个儿子

             这里我们要研究的2-3节点没有4-节点那么为什么要看2-3-4平衡树呢?

             原因就是我们要解决的关键问题:插入元素时,2-3平衡树是如何进行平衡的?

             那么我们把插入进行分类:

                     1.元素插入2-节点           

                     2.元素插入3-节点

                             1.3-节点没有父节点

                             2.3-节点有一个2-节点的父节点

                             3.3-节点有一个3-节点的父节点

                   我们一种一种分析。(下图是依次插入数据)

                    

 


推荐阅读
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 由二叉树到贪心算法
    二叉树很重要树是数据结构中的重中之重,尤其以各类二叉树为学习的难点。单就面试而言,在 ... [详细]
  • 转载自:http:www.blogjava.netCarpenterLeearchive20160427430268.html总体介绍之所以把HashSet和HashMa ... [详细]
  • 在 Flutter 开发过程中,开发者经常会遇到 Widget 构造函数中的可选参数 Key。对于初学者来说,理解 Key 的作用和使用场景可能是一个挑战。本文将详细探讨 Key 的概念及其应用场景,并通过实例帮助你更好地掌握这一重要工具。 ... [详细]
  • 本题探讨了在大数据结构背景下,如何通过整体二分和CDQ分治等高级算法优化处理复杂的时间序列问题。题目设定包括节点数量、查询次数和权重限制,并详细分析了解决方案中的关键步骤。 ... [详细]
  • 一、HashSet1.虑重功能特性(HashMap实现)2.put(key)如果重复返回false***Add ... [详细]
  • 图解HashMap
    什么是HashMap,文章内HashMap源码主要来自Android7.0HashMap是开发中常用的一个类,那么他究竟是什么呢?HashMap是一个存储key-value的集合, ... [详细]
  • HashMap、Hashtable、LinkedHashMap和TreeMap之间的区别Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许& ... [详细]
  • 单线程化的ConcurrentHashMap的性能要比同步的HashMap的性能稍好一些,而且在并发应用中,这种作用就十分明显了。ConcurrentHashMap的实现,假定大多数常用的操 ... [详细]
  • Java集合详解5:深入理解LinkedHashMap和LRU缓存
    Java集合详解5:深入理解LinkedHashMap和LRU缓存今天我们来深入探索一下LinkedHashMap的底层原理,并且使用linkedhashmap来实现LRU缓存。具体代码在我的 ... [详细]
  • Java之HashMap在多线程情况下导致死循环的问题
    PS:不得不说Java编程思想这本书是真心强大..学习内容:1.HashMap<K,V>在多线程的情况下出现的死循环现象当初学Java的时候只是知道HashMap< ... [详细]
  • 缓存这个东西就是为了提高运行速度的,由于缓存是在寸土寸金的内存里面,不是在硬盘里面,所以容量是很有限的。LRU这个算法就是把最近一次使用时间离现在时间最远的数据删除掉。先说说List:每 ... [详细]
  • 类Hashtable<K,V>所有已实现的接口:Serializable,Cloneable,Map<K,V>此类实现一个哈希表,该哈希表将键映 ... [详细]
  • 01Map集合概述A:Map集合概述:我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同a:Collection中的集合 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
author-avatar
kobe24_3803
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有