博客
关于我
大话数据结构——第五章树读书笔记
阅读量:512 次
发布时间:2019-03-07

本文共 836 字,大约阅读时间需要 2 分钟。

树是一种非常重要的数据结构,它在计算机科学中广泛应用于数据存储和处理。拆解树知识点可以从以下几个方面展开:

1. 树的定义

树是一种抽象数据结构,具有以下特点:

  • 任意节点(非根节点)恰好有一个父节点
  • 节点之间通过父节点和子节点的关系连接
  • �uthorizer: 根节点没有父节点,叶子节点没有子节点

树的结构可以用来表示层次化的数据,如文件目录、树形图、生物树等。

2. 树的存储结构

为了方便地存储和访问树的节点,通常可以选择以下存储结构:

  • 数组存储:实用,通过节点编号快速定位节点的位置
  • 链表存储:灵活,适合动态增减节点

数组存储的优点是定位节点简单,但因为节点总数已知时,需事先分配内存空间。链表存储灵活,但在大数据量时可能比数组慢。

3. 二叉树

二叉树是树的重要扩展,具有以下特点:

  • 每个节点最多有两个子节点(左、右)
  • 具体实现方式有顺序存储(数组或链表)

二叉树广泛应用于数据结构排序、查找和图形应用,如 AVL 树和平衡树。

4. 线索二叉树

线索二叉树是一种与线索表类似的结构,结合了节点的信息,用于内存存储数据特征,提高查找效率。线索树的优点是直接通过公式定位节点,节省时间;缺点是占用较多内存。

5. 树与森林的关系

  • 森林由多个不相连的树组成
  • 转换树与森林:需要处理不完整节点,可能叶节点间断
  • 遍历森林可以使用深度优先或广度优先策略

6. 树的遍历

树的遍历是处理树结构的重要方法:

  • 深度优先搜索(DFS):先处理子节点再处理当前节点,如前序遍历
  • 广度优先搜索(BFS):按层次处理节点,如层序遍历

遍历的目的是执行特定操作,如查找节点、统计数据等。

7. 赫夫曼树及其应用

赫夫曼树是一种基于优先队列优化的数据结构,用于数据压缩和加密。其核心思想是最小化节点合并成本,具有频率较高的节点合并较少位数,从而节省存储空间。赫夫曼编码广泛应用于文件压缩、通信等领域。

通过以上拆解,树知识点涵盖了数据结构的基础,了解树的各个方面有助于更好地应用于实际问题。

转载地址:http://ubjnz.baihongyu.com/

你可能感兴趣的文章
OpenMCU(五):STM32F103时钟树初始化分析
查看>>
OpenMCU(四):STM32F103启动汇编代码分析
查看>>
OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
查看>>
OpenMMLab | AI玩家已上线!和InternLM解锁“谁是卧底”新玩法
查看>>
OpenMMLab | S4模型详解:应对长序列建模的有效方法
查看>>
OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
查看>>
OpenMMLab | 不是吧?这么好用的开源标注工具,竟然还有人不知道…
查看>>
OpenMMLab | 如何解决大模型长距离依赖问题?HiPPO 技术深度解析
查看>>
OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
查看>>
OpenMP 线程互斥锁
查看>>
OpenMV入门教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
OpenObserve云原生可观测平台本地Docker部署与远程访问实战教程
查看>>
openoffice使用总结001---版本匹配问题unknown document format for file: E:\apache-tomcat-8.5.23\webapps\ZcnsDms\
查看>>
views
查看>>
OpenPPL PPQ量化(2):离线静态量化 源码剖析
查看>>
OpenPPL PPQ量化(3):量化计算图的加载和预处理 源码剖析
查看>>
OpenPPL PPQ量化(4):计算图的切分和调度 源码剖析
查看>>
OpenPPL PPQ量化(5):执行引擎 源码剖析
查看>>
openpyxl 模块的使用
查看>>
OpenResty & Nginx:详细对比与部署指南
查看>>