数据结构——5.5 树与二叉树的应用

5.5 树与二叉树的应用

在这里插入图片描述

  • 概念
  1. 结点的权:大小可以表示结点的重要性

  2. 结点的带权路径长度:从树的根到该结,的路径长度(经过的边数)与该结点权的乘积

  3. 树的带权路径长度:树中所有叶结点的带权路径长度之和(WPL)

    在这里插入图片描述

  4. 哈夫曼树(最优二叉树):在含有n个带权叶结点的二叉树中,其中带权路径长度(WPL) 最小的二叉树

  5. 编码方式

    1. 每个字符对应二进制长度分:

      1. 固定长度编码,每个字符对应相同长度的二进制编码

      2. 可变长度编码,允许不同字符用不同长度的二进制编码

    2. 按是否有歧义分:

      1. (解码无歧义)前缀编码:没有一个编码是另一个编码的前缀

      2. (解码有歧义)非前缀码

    3. 哈夫曼编码:利用构造哈夫曼树的方法得到哈夫曼编码,左边0,右边1

      在这里插入图片描述

  6. 并查集

    1. 如何查到一个元素到底属于哪一个集合?

      ·指定元案出发,一路向北,找到根节点

    2. 如何断两个元素否属于同一个集合?

      ·分别查到两个元素的根,判断根节点是否相同即可

    3. 如何把两个集合并为一个集合?

      ·让一棵树成为另一棵树的子树即可

    4. 采用双亲表示法存储并查集树的好处

      1. 容易向上溯源(易于查)

      2. 另一棵树的根指向目标树的根即可实现并(易于并)

  • 理解
  1. 哈夫曼树的构造

    在这里插入图片描述

  2. 并查集的实现

    1. 定义:有n个元素则定义大小为n的数组,根的值为-1,其他结点值为根节点的下标

    2. 查操作:往上溯源找到只为-1的根节点的下标(最坏复杂度O[n])

    3. 并操作:两个集合合并成一个,把其中一个集合的根的值改成另一个根节点的下标即可(复杂度O[1])

    4. 并操作的优化:尽可能降低并查集的高度

      1. 修改复杂度为O[1]的并操作,该方法使得构造的树高不超过log₂n(向下取整)+1,从而查操作的复杂度降到O[log₂n]

      2. 每次合并的时候让小树合并到大树的根下

      3. 根的值仍然取负值,但是绝对值是该树的所有节点数目,从而可以体现树的大小

    5. 查操作的优化:压缩路径(复杂度O[α(n)])

      1. 路径上经过的结点都直接挂到根节点下面

        1. while循环向上溯源,目的是找到根(与优化前一样)

        2. 再次while循环,目的是把路上的结点都直接转接到根节点下面(优化内容)(如果每个叶结点都经过这个操作,那么原来的树的高度就变成了2,一个根,其他全是叶子)

    6. 在这里插入图片描述

  3. 在这里插入图片描述

  • 技巧
  1. 在有n个叶子结点的哈夫曼二叉树中,非叶子结点一共有n-1个,总共有2n-1个结点,叶结点个数即为可编码的个数

  2. 哈夫曼编码不超过4,已经编码两个:1、01,则最多还可以编码4个:0000、0001、0010、0011

  3. 哈夫曼二叉树的度只有0和2两种情况

  4. n个有序的序列和m个有序的序列合并,最坏情况要比较m+n-1次大小

相关推荐

  1. 数据结构实验5:应用

    2024-02-11 18:10:01       24 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-11 18:10:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-11 18:10:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-11 18:10:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-11 18:10:01       20 阅读

热门阅读

  1. Leetcode 121 买卖股票的最佳时机

    2024-02-11 18:10:01       33 阅读
  2. 94 . 二叉树的中序遍历 -- 2024.2.10 LeetCode每日一题

    2024-02-11 18:10:01       39 阅读
  3. 完全背包总结二

    2024-02-11 18:10:01       30 阅读
  4. Elasticsearch中的模板:定义、作用与实践

    2024-02-11 18:10:01       35 阅读
  5. 计算机网络(第六版)复习提纲29

    2024-02-11 18:10:01       29 阅读
  6. 2023年股市总结,2024年A股方向展望!

    2024-02-11 18:10:01       35 阅读
  7. 前端开发_Node.js

    2024-02-11 18:10:01       25 阅读
  8. C语言什么是悬空指针?

    2024-02-11 18:10:01       35 阅读
  9. Leetcode 518 零钱兑换 II

    2024-02-11 18:10:01       27 阅读
  10. 线程池设计---C++

    2024-02-11 18:10:01       24 阅读
  11. JDK8常用:JVM参数

    2024-02-11 18:10:01       19 阅读
  12. STL之priority_queue的使用及其模拟实现+仿函数

    2024-02-11 18:10:01       26 阅读