40.常见数据结构:二叉树、二叉查找树、平衡二叉树、红黑树

二叉树,二叉查找树

  • 当没有父节点时(即祖宗节点),父节点地址为null

    当没有左子节点时,左子节点地址为null

    当没有右子节点时,右子节点地址为null

  • 根节点(或称祖宗节点)的右侧的所有结点称为右子树;左侧称为左子树

  • 特点

    • 只能有一个根节点,每个节点最多支持2个直接子节点

    • 节点的度:节点拥有的子树的个数,二叉树的度不大于2;叶子节点度为0的节点,也称之为终端节点

    • 高度:叶子节点的高度为1;叶子节点的父节点高度为2;根节点的位置最高

      即从叶子节点往上数层数

    • 层:根节点在第一层,往下数依次类推

    • 兄弟节点:拥有共同父节点的节点互称为兄弟节点(同层不同父的也可以认为是堂兄节点)

  • 二叉查找树(又称二叉排序树或二叉搜索树)

    大的节点到小的节点,依次从右往左排

    • 特点:
      1. 每一个节点上最多有两个子节点
      2. 左子树上所有节点的值都小于根节点的值
      3. 右子树上所有节点的值都大于根节点的值
    • 目的:提高检索数据的性能
    • 二叉查找树添加节点规则:
      1. 小的存左边
      2. 大的存右边
      3. 一样的不存
    • 二叉查找树是一种增删改查都很快的数据结构,趋近于完美

平衡二叉树

  • 普通二叉查找树的弊端:在添加元素时可能出现”变成链表“的情况,即根节点和所有子节点的度为1,名义上是二叉树,实际上已经变成了链表,操作效率瞬间变低

  • 为解决二叉查找树的弊端,引入平衡二叉树的概念,在满足二叉查找树的条件下,尽可能的让度为2,使得二叉树的高度变得矮小,尽可能的均匀,性能进一步提高

  • 平衡二叉树的要求

    • 任意节点的左右两个子树的高度差不超过1,任意节点的左右两个子树都是一棵平衡二叉树
  • 平衡二叉树在添加元素后可能导致不平衡

    • 基本策略是进行左旋,或者右旋保证平衡

      • 左旋

        [图片上传失败...(image-f55cc8-1647070245558)]

      • 右旋

        [图片上传失败...(image-1e6637-1647070245558)]

    • 旋转的四种情况

      • 左左
        • 当根节点左子树的左子树有节点植入,导致二叉树不平衡(右旋)
      • 左右
        • 当根节点左子树的右子树有节点插入,导致二叉树不平衡
          • 以不平衡的节点为支点,先左旋再右旋(参考下方右左示意图)
      • 右右
        • 当根节点右子树的右子树有节点插入,导致二叉树不平衡(左旋)
      • 右左
        • 当根节点右子树的左子树有节点插入,导致二叉树不平衡
          • 以不平衡的节点为支点,先右旋再左旋
          • image.png

红黑树

  • 红黑树是一种自平衡的二叉查找树,是计算机科学中的一种数据结构

  • 又称平衡二叉B树

  • 每一个节点可以是红或黑,红黑树不是通过高度平衡的,它的平衡是通过“红黑规则”进行实现的

  • 红黑规则

    • 每一个节点或红或黑,根节点必须是黑色的
    • 如果一个节点没有子节点或者父节点,则该节点相应的指针属性值为Nil,这些Nil视为叶节点,叶节点是黑色的
    • 如果某一个节点是红色的,那么它的子节点必须是黑色的(不能出现两个红色节点相连的情况)
    • 对每一个节点,从该节点到其所有后代叶节点的简单路径上,均包含相同数目的黑色节点
  • 相比普通二叉树,红黑树的构成多了一个区域标记颜色值

  • 添加节点

    • 添加的节点的颜色,可以是红色,也可以是黑色

    • 默认使用红色效率更高

      因为红节点不在红黑规则的路径算法里,默认添加使用黑色会导致需要大量的调整工作以保障每次添加后平衡

    • 当出现子节点的父节点是红色,即两个红色相连接时,判断:父节点是否为红色,叔叔节点(父节点的兄弟节点)是否为红色;判断得出父节点和叔叔节点均为红时

      1. 将父节点设为黑色;将叔叔节点设为黑色
      2. 将祖父节点(父节点和叔叔节点的父节点)设为红色
      3. 判断祖父节点是否为根节点,是根节点时将根节点再次变为黑色
    • 当出现父节点是红色,叔叔节点是黑色

      1. 将父节点设为黑色
      2. 将祖父节点设为红色
      3. 以祖父节点为支点进行旋转
  • 红黑树的增删改查性能都非常好

总结

  • 栈:后进先出,先进后出
  • 队列:先进先出,后进后出
  • 数组:内存连续区域,查询快,增删慢
  • 链表:元素是游离的,查询慢,首位操作极快
  • 二叉树:永远只有一个根节点,每个节点不超过2个子节点的树
  • 查找二叉树:小的放左边,大的放右边,极端情况下,树的高度过高使得查询性能变差
  • 平衡查找二叉树:让树的高度差不大于1,增删改查效率都比较高
  • 红黑树:基于红黑规则实现的自平衡的排序二叉树,增删改查效率都很高
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容