当前位置: 首页 > news >正文

数据结构 (18)数的定义与基本术语

前言

       数据结构是计算机科学中的一个核心概念,它描述了数据元素之间的关系以及这些元素在计算机中的存储方式。

一、数的定义

       在计算机科学中,“数”通常指的是树形数据结构,它是一种非线性的数据结构,由节点(或称为元素)和连接这些节点的边组成。树形结构有一个特殊的节点称为根节点,其余节点则可以划分为若干个不相交的子集,每个子集也是一个树形结构,称为根节点的子树。

二、基本术语

  1. 节点(Node)
    • 树形结构的基本单位,它包含数据部分和指向其子节点的指针(或链接)。
    • 在某些情况下,节点也被称为元素、顶点或记录。
  2. 根节点(Root Node)
    • 树形结构的起始节点,没有父节点。
    • 在树中,所有其他节点都是根节点的后代。
  3. 子节点(Child Node)
    • 一个节点的直接后继节点,通过边与父节点相连。
    • 一个节点可以有多个子节点。
  4. 父节点(Parent Node)
    • 一个节点的直接前驱节点,通过边与子节点相连。
    • 除根节点外,每个节点都有一个父节点。
  5. 兄弟节点(Sibling Nodes)
    • 具有相同父节点的节点。
  6. 叶子节点(Leaf Node)
    • 没有子节点的节点。
    • 在树中,叶子节点位于最底层。
  7. 树的深度(Depth of Tree)
    • 树中节点的最大层次数(从根节点开始计算)。
    • 树的深度也称为树的高度。
  8. 树的度(Degree of Tree)
    • 树中节点的最大子节点数。
    • 需要注意的是,树的度与节点的度是两个不同的概念。节点的度是指该节点的子节点数。
  9. 森林(Forest)
    • 零个或多个不相交的树组成的集合。
    • 森林可以看作是没有根节点的特殊树形结构。
  10. 有序树(Ordered Tree)
    • 树中节点的子节点是有序的,即每个节点的子节点按一定顺序排列。
    • 在有序树中,子节点的位置是重要的。
  11. 无序树(Unordered Tree)
    • 树中节点的子节点是无序的,即每个节点的子节点没有特定的排列顺序。
    • 在无序树中,子节点的位置是不重要的。

三、树的种类

     根据树的结构特点,可以将树分为多种类型:

  1. 二叉树(Binary Tree)
    • 每个节点最多有两个子节点,分别称为左子节点和右子节点。
    • 二叉树是树形结构中最常见和最重要的一种。
  2. 平衡二叉树(Balanced Binary Tree)
    • 一种特殊的二叉树,其中任何节点的两个子树的高度差不超过1。
    • 平衡二叉树通常用于实现高效的搜索和排序操作。
  3. B树(B-Tree)
    • 一种自平衡的树,能够保持数据有序,允许搜索、顺序访问、插入和删除等操作在对数时间内完成。
    • B树广泛用于数据库和文件系统的索引结构中。
  4. 红黑树(Red-Black Tree)
    • 一种自平衡的二叉搜索树,其中每个节点都存储一个额外的位来表示节点的颜色(红色或黑色)。
    • 红黑树通过颜色的约束来保持树的平衡性,从而确保搜索、插入和删除操作的高效性。
  5. 堆(Heap)
    • 一种特殊的完全二叉树,其中每个节点的值都大于或等于其子节点的值(最大堆)或小于或等于其子节点的值(最小堆)。
    • 堆通常用于实现优先队列和堆排序等操作。
  6. Trie树(Trie Tree)
    • 一种用于存储字符串集合的树形数据结构,其中每个节点表示字符串的一个字符。
    • Trie树通常用于实现高效的字符串搜索和前缀匹配操作。

四、树的操作

     在树形数据结构中,常见的操作包括:

  1. 搜索(Search)
    • 在树中查找具有特定值的节点。
    • 搜索操作的时间复杂度取决于树的结构和搜索算法。
  2. 插入(Insert)
    • 在树中添加一个新的节点。
    • 插入操作需要保持树的平衡性和有序性(如果适用)。
  3. 删除(Delete)
    • 从树中移除一个节点。
    • 删除操作需要保持树的平衡性和有序性(如果适用),并处理可能的子树合并或重新平衡。
  4. 遍历(Traversal)
    • 按照一定顺序访问树中的每个节点。
    • 常见的遍历方法包括前序遍历、中序遍历和后序遍历(对于二叉树)以及层次遍历(按层次从上到下、从左到右访问节点)。

总结

       综上所述,数据结构中的“数”(树形结构)是一种重要的非线性数据结构,具有广泛的应用场景和丰富的操作。通过掌握树的基本术语和种类以及常见的操作方法,可以更好地理解和应用树形数据结构来解决实际问题。

 结语   

没有无义务的权利

也没有无权利的义务

!!!

相关文章:

数据结构 (18)数的定义与基本术语

前言 数据结构是计算机科学中的一个核心概念,它描述了数据元素之间的关系以及这些元素在计算机中的存储方式。 一、数的定义 在计算机科学中,“数”通常指的是树形数据结构,它是一种非线性的数据结构,由节点(或称为元素…...

Flink的双流join理解

如何保证Flink双流Join准确性和及时性、除了窗口join还存在哪些实现方式、究竟如何回答才能完全打动面试官呢。。你将在文中找到答案。 1 引子 1.1 数据库SQL中的JOIN 我们先来看看数据库SQL中的JOIN操作。如下所示的订单查询SQL,通过将订单表的id和订单详情表ord…...

《使用Python进行数据挖掘:理论、应用与案例研究》

嘿,今天我要给你们介绍一本使用Python进行数据挖掘的好书。这本书是由吴迪博士撰写的,他是雷曼学院商学院的助理教授,也是数据科学的实战派。 在这个时代,数据多得让人眼花缭乱,要从中找出有用的信息,那可不…...

Go语言技巧:快速统一字符串中的换行符,解决跨平台问题

统一字符串中的 Windows \r\n 换行符 — Go语言实现 在编程中,尤其是处理跨平台的文本数据时,换行符的处理是一个常见的问题。Windows 系统使用 \r\n 作为换行符,而 Unix-like 系统(如 Linux 和 macOS)使用 \n。在 Go…...

算法训练营day20(二叉树06:最大二叉树,合并二叉树,搜索二叉树,验证搜索二叉树)

第六章 二叉树 part06 今日内容 ● 654.最大二叉树 ● 617.合并二叉树 ● 700.二叉搜索树中的搜索 ● 98.验证二叉搜索树 详细布置 654.最大二叉树 又是构造二叉树,昨天大家刚刚做完 中序后序确定二叉树,今天做这个 应该会容易一些, 先看视…...

Leetcode(区间合并习题思路总结,持续更新。。。)

讲解题目:合并区间 以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间, 并返回一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间。示例 1:输入&a…...

『python爬虫』使用docling 将pdf或html网页转为MD (保姆级图文)

目录 预览效果安装下载模型测试代码总结 欢迎关注 『python爬虫』 专栏,持续更新中 欢迎关注 『python爬虫』 专栏,持续更新中 预览效果 支持转化pdf的表格 安装 Docling 本身是专注于文档转换的工具,通常用于将文件(如 PDF&…...

elasticsearch现有集群扩展节点

原文地址:elasticsearch现有集群扩展节点 – 无敌牛 欢迎参观我的个人博客:无敌牛 – 技术/著作/典籍/分享等 给现有的 elasticsearch 集群扩展节点比较容易,已有的集群不需要做任何修改,也不用对服务做任何处理,只需…...

力扣162:寻找峰值

峰值元素是指其值严格大于左右相邻值的元素。 给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。 你可以假设 nums[-1] nums[n] -∞ 。 你必须实现时间复杂度为 O(…...

Kafka-Connect

一、概述 Kafka Connect是一个在Apache Kafka和其他系统之间可扩展且可靠地流式传输数据的工具。细心的你会发现,我们编写的producer、consumer都有很多重复的代码,KafkaConnect就是将这些通用的api进行了封装。让我们可以只关心业务部分(数…...

递归、搜索与回溯算法 - 3 ( floodfill 记忆化搜素 9000 字详解 )

一:floodfill 算法 1.1 图像渲染 题目链接:图像渲染 class Solution {// 首先先定义四个方向的向量int[] dx {0, 0, 1, -1};int[] dy {1, -1, 0, 0};// 接着用 m 记录行数,n 记录列数,prev 记录 (sr, sc) 位置的…...

YOLOv9改进,YOLOv9引入CAS-ViT(卷积加自注意力视觉变压器)中AdditiveBlock模块,二次创新RepNCSPELAN4结构

摘要 CAS-ViT 是一种为高效移动应用设计的视觉Transformer。模型通过结合卷积操作与加性自注意机制,在保持高性能的同时显著减少计算开销,适合资源受限的设备如手机。其核心组件 AdditiveBlock 通过多维度信息交互和简化的加性相似函数,实现了高效的上下文信息整合,避免了…...

HDLCPPP原理与配置

前言: 广域网中经常会使用串行链路来提供远距离的数据传输,高级数据链路控制HDLC( High-Level Data Link Control )和点对点协议PPP( Point to Point Protocol)是两种典型的串口封装协议。 HDLC协议: 原理…...

react + vite 中的环境变量怎么获取

一、Vite 环境变量基础 创建一个.env文件,Vite 定义的环境变量需要以VITE_开头。 VITE_API_URL "http://localhost:3000/api" 生产模式创建.env.production。 VITE_API_URL "https://production-api-url.com/api" 二、在 React 组件中获…...

知识蒸馏中有哪些经验| 目标检测 |mobile-yolov5-pruning-distillation项目中剪枝知识分析

项目地址:https://github.com/Syencil/mobile-yolov5-pruning-distillation 项目时间:2022年 mobile-yolov5-pruning-distillation是一个以yolov5改进为主的开源项目,主要包含3中改进方向:更改backbone、模型剪枝、知识蒸馏。这里…...

Oracle 19c RAC单节点停机维护硬件

背景 RAC 环境下一台主机硬件光纤卡不定时重启,造成链路会间断几秒,期间数据库会话响应时间随之变长,该光纤卡在硬件厂商的建议下,决定停机更换备件,为保证生产影响最小,决定停掉该节点,另外节…...

Linux系统 进程

Linux系统 进程 进程私有地址空间用户模式和内核模式上下文切换 进程控制系统调用错误处理进程控制函数获取进程 ID创建和终止进程回收子进程让进程休眠加载并运行程序 进程 异常是允许操作系统内核提供进程(process)概念的基本构造块,进程是…...

机载视频流回传+编解码方案

无线网络,低带宽场景。不能直接转发ROS raw image(10MB/s),而要压缩(编码)后再传输。可以用rtsp的udp传输或者直接传输话题,压缩方法有theora(ROS image_transport默认支持&#xff…...

Ubuntu 20.04 Server版连接Wifi

前言 有时候没有网线口插网线或者摆放电脑位置不够时,需要用Wifi联网。以下记录Wifi联网过程。 环境:Ubuntu 20.04 Server版,无UI界面 以下操作均为root用户,如果是普通用户,请切换到root用户,或者在需要权…...

【VRChat 改模】开发环境搭建:VCC、VRChat SDK、Unity 等环境配置

一、配置 Unity 相关 1.下载 UnityHub 下载地址:https://unity.com/download 安装打开后如图所示: 2.下载 VRChat 官方推荐版本的 Unity 跳转界面(VRChat 官方推荐页面):https://creators.vrchat.com/sdk/upgrade/…...

从配置字到实际运动:手把手教你用EtherCAT调试伺服电机的控制模式(以倍福TwinCAT3为例)

从配置字到实际运动:手把手教你用EtherCAT调试伺服电机的控制模式(以倍福TwinCAT3为例) 在工业自动化现场,伺服电机的精准控制往往决定着整条产线的运行效率。当面对一台全新的伺服驱动器时,如何快速完成从参数配置到实…...

从老式收音机到现代Wi-Fi:聊聊AM调幅技术为何还没被淘汰?

从老式收音机到现代Wi-Fi:AM调幅技术的百年生存法则 清晨六点,美国中西部农场主约翰习惯性拧开那台1947年产的Zenith Trans-Oceanic收音机,沙沙声中传来农业气象预报;与此同时,东京秋叶原的工程师山田正用软件无线电接…...

NCM音乐解锁终极指南:3步实现网易云音乐格式自由转换

NCM音乐解锁终极指南:3步实现网易云音乐格式自由转换 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 还在为网易云音乐下载的NCM加密文件无法在其他播放器使用而烦恼吗?ncmdump解密工具让你轻松突破格式限制&…...

BGA虚焊别头疼!从焊膏印刷到回流焊曲线,一份保姆级的SMT工艺避坑指南

BGA虚焊别头疼!从焊膏印刷到回流焊曲线,一份保姆级的SMT工艺避坑指南 在SMT产线上,BGA虚焊问题就像个幽灵,时不时冒出来折腾工程师。上周产线刚报修一批主板,X光下那些不规则焊点像极了抽象派画作——可惜客户要的是工…...

Mac小白必看:手把手教你找回丢失的Recovery HD分区(附diskutil命令详解)

Mac用户必备技能:深度解析Recovery HD分区修复与diskutil实战指南 当你按下CommandR却只看到闪烁的问号图标时,那种手足无措的感觉我深有体会。Recovery HD分区就像是Mac的急救箱,藏着系统恢复、磁盘修复和时间机器备份等关键工具。但很多用户…...

Windows Defender Remover终极指南:高效移除Windows安全防护的完整解决方案

Windows Defender Remover终极指南:高效移除Windows安全防护的完整解决方案 【免费下载链接】windows-defender-remover A tool which is uses to remove Windows Defender in Windows 8.x, Windows 10 (every version) and Windows 11. 项目地址: https://gitcod…...

Ciao故障排除终极指南:10个常见问题与解决方案大全

Ciao故障排除终极指南:10个常见问题与解决方案大全 【免费下载链接】ciao HTTP checks & tests (private & public) monitoring - check the status of your URL 项目地址: https://gitcode.com/gh_mirrors/ci/ciao Ciao是一款强大的HTTP(S) URL监控…...

NLP基石:从n-gram到现代语言模型的演进之路

1. 语言模型的起源与核心思想 语言模型这个概念最早可以追溯到上世纪中叶的信息论研究。当时科学家们试图用数学方法描述人类语言的规律性,于是提出了"用概率衡量句子合理性"的基本思路。想象一下,当你听到"今天天气真好"和"天…...

如何学习java?

目录 一. 初识Java 1. Java语⾔概述 1.1 Java是什么 1.2 什么是JavaSE?什么是JavaEE? JavaSE(JavaStandardEdition): JavaEE(JavaEnterprise Edition): 主要区别: 1.3 Java语⾔重要性 1.4 Java语⾔发展简史 1.5 Java语⾔特性 1.6 Java开发环境安装 1. …...

别再只会用save了!Matlab fwrite函数实战:手把手教你高效读写二进制文件(附完整代码)

Matlab二进制文件高效读写指南:fwrite函数深度解析与实战 在数据处理领域,二进制文件因其紧凑性和高效性而备受青睐。对于Matlab用户而言,虽然save函数简单易用,但在处理大规模数据或需要跨平台交换时,fwrite函数才是…...