数据结构(1)前言

2023-11-06

(1)学习数据结构前,需要掌握结构体和指针的使用,需要了解typedef这个关键字。对这部分知识欠缺的可以查看:C语言结构体详解何为指针,与数组名有什么区别

(2)作为一名想成为嵌入式软件工程师的人而言,很多像电气工程,电子信息等专业的人在大学期间并没有开设数据结构这一课程。但是这一课程确实很重要,有很多人会说,数据结构在工作中用不到。但是我个人认为,如果100人中有20人说需要学,那么就需要学的理念来学习数据结构。

(3)如要自学数据结构,强烈推荐购买程杰老师的大话数据结构。通俗易懂,图文结合。

(4)邀请加入嵌入式社区,您可以在上面发布问题,博客链接,公众号分享,行业消息,招聘信息等。

目录

数据结构的起源

基本概念和术语

数据

数据元素

数据项

数据对象

数据结构 

逻辑结构与存储结构(物理结构)

逻辑结构

集合结构

线性结构

数形结构

图形结构

存储结构(物理结构)

顺序存储

链式存储结构(重点)

索引存储

散列存储 

总结


数据结构的起源

(1)数据结构前身是1968年美国的高德纳教授所写的《计算机程序设计艺术》。C语言是于1972年才产生的,而《计算机程序设计艺术》这本书是1968年就有了,所以语言不重要,主要是它的数据存储的思想。不过,我这个专栏是以C语言进行简单讲解数据结构的知识。

(2)数据结构主要是研究数据逻辑结构存储结构及其操作

基本概念和术语

这部分有一个简单了解即可,之后对数据结构有了一定理解之后可以回来再看。

数据

数据:是描述客观实物的符号,计算机信息的载体。能够输入到计算机,并且被计算机识别、存储和处理的符号总称

 数据包括整型、实型等数值类型,还包括声音、图像、视频等非数值类型。首先,对于数值类型而言,比如50是一个数值,但对于计算机而言,就是字符‘5’和‘0’。所以整型是属于数据。

而声音、图像、视频等也可以以符号的形式呈现,比如声音有音符,我们可以利用数字1代表某一个音符,数字2代表另外一个音符。最后将这些数字输入到计算机,能够被计算机处理。所以声音也是数据。

数据元素

数据元素:组成数据的,有一定意义的基本单位,在计算机中通常作为整体处理,也被称之为记录。

举个例子,人类是数据,可以用“people”这一串字符代替。而人,比如张三,李四就是属于数据元素。

数据项

数据项:一个数据元素可以由若干数据项组成。数据项是数据不可分割的最小单位

人类是数据,人是数据元素,而每一个人都有眼睛,耳朵,鼻子,性别,年龄等数据项。虽然数据项是数据的最小单位,但是我们一般是以数据元素进行分析。

数据对象

数据对象:性质相同的数据元素的集合,数据的子集。因为一般处理的数据元素具有相同性质,所以一般都将数据对象简称为数据

数据结构 

(1)结构:不同的数据元素之间不是独立的,而是有特定的关系。

(2)数据结构:相互之间存在一种或者多种特定关系的数据元素的集合。

比如人类是数据,张三,李四,王五是数据元素。张三是李四的丈夫,王五是张三的弟弟这种夫妻关系,兄弟关系我们称之为结构。张三,李四,王五他们之间被称之为家人,所以他们三个可以被称之为数据结构。

逻辑结构与存储结构(物理结构)

逻辑结构

(1)逻辑结构:逻辑结构是指数据对象中的数据元素之间的相互关系。这个是我们需要重点关注的问题。

(2)逻辑结构分为集合结构线性结构树形结构图形结构四种。

集合结构

集合结构:集合结构中的数据元素处理同属于一个集合外,没有任何其他关系。基本上不考虑这种情况。

线性结构

(1)线性结构:线性结构中的数据元素之间是一对一的关系。

(2)例如我们在超市里面,购买完东西之后,排队结账,这种一个跟着一个的队列,就是属于线性结构。

 

数形结构

(1)树形结构:树形结构中的数据元素之间是存在一对多的层次关系

(2)例如如下的公司关系图,一个老板,老板下面有多个总裁,总裁下面再细分。是呈现一个对多个的关系。

 

图形结构

(1)图形结构:图形结构的数据元素是多对多的关系。

(2)例如甄嬛传里面,各位娘娘之间的勾心斗角,娘娘A与娘娘B,C是朋友与娘娘D是敌人。娘娘B与娘娘C是敌人,而娘娘C与D又是朋友。各位娘娘各种秀操作,最后干掉对方。这种错综复杂的多对对的结构就是图形结构。

存储结构(物理结构)

(1)存储结构:数据的逻辑结构在计算机中的存储形式,或者说具体实现方法。也称为物理结构

(2)存储结构是通过计算机语言所编写的程序来实现的,因而是依赖于具体的计算机语言

(3)存储结构也有四种,顺序存储链式存储索引存储散列存储。不过大话数据结构里面说只有顺序存储和链式存储两种,我猜可能是后两种使用的比较少。

顺序存储

(1)顺序存储结构:是把数据元素存放在地址连续的存储单元里,其数据之间的逻辑关系和物理关系是一致的

(2)例如C语言的数组。数组的数据都是连续的,这就是物理关系。a1后面必然是a2,当我们知道了a0的地址,那么数组的任意元素地址也知道了,他们是连续的,这就是逻辑关系

 

链式存储结构(重点)

(1)链式存储结构:将数据结构中的各元素分布到存储器的不同点,用地址(或链指针)方式建立他们之间的联系。这些元素的存储单元可以是连续的,也可以是不连续的

(2)这有什么好处呢?比如,在医院排队叫号,有1-100个号码牌。如果是按照顺序存储的方式,先到的人拿到前面的号码牌,1号看完之后来2号,2号看完之后来3号。突然,来了一个重症老年患者,需要插队,所有人往后顺延一个位置。突然,有人不愿意了,又不是我家人,重症了管我我什么事情,我得病了不是病吗?先来后到不懂吗?

按照顺序存储的方式,插队位置后面所有人进行安抚,向后顺延一个位置比较麻烦。这个时候我们是不是可以对这个结构进行调整,变成链式存储结构。

依旧是还有1-100个号码牌。只不过这一次不是按照顺序发放号码牌,比如甲先到了,但是发45号,乙后到,发34号,丙发88号。然后护士那一个记事本,记住显示45号,再34号,再88号。按照这个顺序排队,如果突然来了一个重症老人,我可以直接将45号后面变成老人,老人后面是34号。虽然需要一个护士进行做记录有点麻烦,但相比需要将后面的所有人进行顺延,安抚相比简单很多事情。

(3)虽然有好处,但是还是有缺点的。第一,需要多一个护士进行记录,对空间上增加了损耗第二,不透明。如果是顺序存储,我一眼就可以知道前面有多少人在排队。但是如果是链式存储,我不知道前面有多少个。如果我要找到我的位置,就需要看一下记事本,从第一个人从后面依次寻找,直到找到我自己第三数据元素数量未知。如果护士突然想直到,今天一共来了多少个人看诊,就需要从第一个一个一个的数,一直数到最后一个号码牌。

 

索引存储

(1)索引存储:在存储数据的同时,建立一个附加的索引表,及索引存储结构=数据文件+索引表(目录)。

(2)例如,我们购买一本书,他们都会有一个目录。就像我写博客也会有一个目录。我们可以根据这个目录找到我们想要的具体内容。索引表就是目录,数据文件就是我们所写的内容。

 

散列存储 

散列存储:根据数据元素的特殊字段(称为关键字key),计算出数据元素的存放地址,然后数据元素按照地址存放。简单了解一下即可,在查找部分会讲解。

总结

(1)本文简单了解了数据结构的概念和术语。数据,数据元素,数据项,数据对象和数据结构是什么意思。

(2)数据的逻辑结构有四种。 

(3)数据的存储结构也有四种。 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

数据结构(1)前言 的相关文章

  • PyTorch自然语言处理

    特点 展示如何使用基于 Python 的深度学习库 PyTorch 应用这些方法 演示如何使用 PyTorch 构建应用程序 探索计算图和监督学习范式 掌握 PyTorch 优化张量操作库的基础知识 概述传统的 NLP 概念和方法 学习构建
  • python将折线平滑为曲线

    目录 曲线的曲率介绍 平滑方法介绍 1 环境及模块介绍 2 代码示例 3 整体代码 曲线的曲率介绍 曲线的曲率 curvature 就是针对曲线上某个点的切线方向角对弧长的转动率 通过微分来定义 表明曲线偏离直线的程度 数学上表明曲线在某一
  • 编译器预定义总结.

    http sourceforge net p predef wiki Compilers ACC Type Macro Identification ACC Altium MicroBlaze C Type Macro Format Des
  • Faq about multimedia

    VCN Video Compression Networking Glossary This is a collection of often used and misused technical terms regarding video
  • 【基础知识】11、github上传本地代码

    第一步 下载git bash 下载链接 按步骤安装即可 第二步 配置git bash 一 输入ssh keygen t rsa C 24428078 qq com 获取钥匙 邮箱为github注册的邮箱 输入上述命令时注意空格 出现下面界面

随机推荐

  • bootstrap引入

  • pww区域连接特征提取算法

    主题思想 任何一个图像 肯定由多个或一个区域 每个区域在横向扫描时 会有分裂和合并 比如圆环 顶部有一个分裂点 底部有一个合并点 没有分裂合并的图形 就是简单的凸图像 很容易通过外形识别 而复杂的图像 就是凹的 就需要分裂合并点来识别 旋转
  • 动作捕捉(Motion Capture)文件BVH的解读笔记

    Bvh里面的JOINT 以及ROOT 都表示一个坐标空间 我们称之为关节坐标空间 在这个坐标空间里 它有下一级的子坐标空间 也就是下一级的JOINT 子坐标空间的原点位置由子JOINT的OFFSET字段指明 也就是说一个JOINT的OFFS
  • Linux系统内核文件Cache管理机制简介

    1 前言 自从诞生以来 Linux 就被不断完善和普及 目前它已经成为主流通用操作系统之一 使用得非常广泛 它与 Windows UNIX 一起占据了操作系统领域几乎所有的市场份额 特别是在高性能计算领域 Linux 已经成为一个占主导地位
  • 一文让前端搞懂shell编程

    概述 前端程序员有时会遇到部署项目的情况 有时需要看懂后台或者运维写的脚本 如果转型AI 数据分析和模型训练也经常用到shell编程 掌握shell编程 你的编程之路会越走越宽 shell 解析器 sudo cat etc shells t
  • Win7下使用U盘安装Ubuntu16.04双系统图文教程(亲测)

    安装步骤 1 下载Ubuntu 16 04镜像软件 2 使用ultraISO软件制作U盘启动盘 3 利用U盘启动盘来安装Ubuntu系统 4 使用EasyBCD创建启动系统启动引导 可以省略 5 重启系统即可 一 下载ubuntu16 04
  • 使用Semaphore 实现一个简单的限流器

    使用Semaphore 实现一个简单的限流器 java api Java的api中 提供了semaphore这个线程同步的辅助类 用来控制同时访问共享资源的线程数量 Semaphore提供的主要方法如下 void acquire 获取一个信
  • NUC10 i7 黑苹果Big Sur 11.4 + win10 双系统安装指南

    说明 硬件 Intel NUC 10代 i7 10710U 系统说明 Mac OS Big Sur 11 4 Windows 10 注 本文默认已经安装好windows 安装过程就和普通的单系统安装步骤一样 安装步骤略 其他说明 由于个人知
  • 协同过滤与矩阵分解

    协同过滤算法的基本原理 用户行为数据是推荐系统最常用 也是最关键的数据 用户的潜在兴趣 用户对物品的评价好坏都反映在用户的行为历史中 而协同过滤算法 就是一种完全依赖用户和物品之间行为关系的推荐算法 我们从它的名字 协同过滤 中 也可以窥探
  • 2022高教杯思路合集!!全国大学生数学建模竞赛

    2022高教杯将于9 15开赛 思路贴将于晚10点前发布 粉丝可见 17日0 00转免 国一F奖3年数学建模经验团队 交流Q群 882663918 下文是2022年美赛的思路示例 要求由于公司的规定 ICM公司无法与您的团队分享关于他们的人
  • android 全局悬浮窗 可点击_Hi Translate 全局翻译外语 App 上的内容

    英文不太好的朋友可能在使用某些国外 App 在无中文语言支持的时候 也许 Hi Translate 这款 Android 应用可以帮助到你 这款应用不是简单的外语翻译 它可以在你使用满是外语的 App 时 帮助你实现全局页面翻译成中文 Hi
  • IDEA 集成 Sonar 完整流程

    目录 背景 相关的模块及关系 插件安装 SonarQube 启动 SonarQube 创建工程 插件配置 1 打开插件通用配置界面 2 点击 号添加 SonarServer 3 下一步配置认证信息 4 SonarLint 项目配置 mave
  • C++ char*两种初始化为零的方式

    C 中 char 两种初始化为零的的常用方式有以下两种 char data new char 50 char data memset data 0 50
  • ios-消息中心 NSNotificationCenter 的介绍

    1 通知中心概述 通知中心实际上是在程序内部提供了消息广播的一种机制 通知中心不能在进程间进行通信 实际上就是一个二传手 把接收到的消息 根据内部的一个消息转发表 来将消息转发给需要的对象 通知中心是基于观察者模式的 它允许注册 删除观察者
  • C++17入门经典

    C 17入门经典 注意 第1章 基本概念 第2章 基本数据类型 第3章 处理基本数据类型 第4章 决策 第5章 数组和循环 第6章 指针和引用 第7章 操作字符串 第8章 定义函数 第9章 函数模板 第10章 程序文件和预处理指令 第11章
  • python 修饰器 参数_Python修饰器讲解

    转自 http www cnblogs com rollenholt archive 2012 05 02 2479833 html 文章先由stackoverflow上面的一个问题引起吧 如果使用如下的代码 makebold makeit
  • 语义分割--PANet和Understanding Convolution for Semantic Segmentation

    语义分割 PAN Pyramid Attention Network for Semantic Segmentation FCN作为backbone的结构对小型目标预测不佳 论文认为这存在两个挑战 物体因为多尺度的原因 造成难以分类 针对这
  • J2EE规范技术

    原文 http blog csdn net erikxu archive 2004 12 07 208170 aspx J2EE的13种核心技术 1 JDBC Java Data Base Connectivity java数据库连接 是一
  • Unity3D 中使用OnTiggerEnter遇到的不触发问题

    移动GameObject 绑定BoxCollider Istrigger选中 固定GameObject 绑定BoxCollider 刚体属性 IsKinematic选中 此种情况下 移动GameObject中的OnTriggerEnter
  • 数据结构(1)前言

    1 学习数据结构前 需要掌握结构体和指针的使用 需要了解typedef这个关键字 对这部分知识欠缺的可以查看 C语言结构体详解 何为指针 与数组名有什么区别 2 作为一名想成为嵌入式软件工程师的人而言 很多像电气工程 电子信息等专业的人在大