数据结构(1)前言

news2024/12/26 10:42:41

(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)数据的存储结构也有四种。 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/113536.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一次性记录关键字,注释,字符串值,运算符,括号配对的位置,并设置自定义数据颜色。

未执行函数之前&#xff1a; 执行后参数未加数据&#xff1a; 执行后参数加上数据&#xff1a; 源代码&#xff1a; /// <summary> /// 一次性记录关键字&#xff0c;注释&#xff0c;字符串值&#xff0c;运算符&#xff0c;括号配对的位置,并设置自定义数据颜色 /// &l…

关于Spring的两三事:神奇的注解

一、前言 在之前的学习中我们介绍了注解实际上起到的是标记和注释的作用&#xff0c;其本身并不提供任何的逻辑处理能力。也就是说如果想让注解能够实现预期的作用&#xff0c;就必须给注解搭配一个能够读取并处理该注解的方法&#xff0c;这里为了方便描述我将这样一个方法定义…

小学生C++编程基础 课程11(共8题)

946.数的数字和(课程A&#xff09; 难度&#xff1a;1 登录 947.数的颠倒 ( 课程A&#xff09; 难度&#xff1a;1 登录 948.求8的个数 (课程A&#xff09; 难度&#xff1a;1 登录 949.删除数字0 (课程A&#xff09; 难度&#xff1a;1 登录 950.垒三角形 (课程A&#xff…

RabbitMQ 第二天 高级 7 RabbitMQ 高级特性 7.6 延迟队列

RabbitMQ 【黑马程序员RabbitMQ全套教程&#xff0c;rabbitmq消息中间件到实战】 文章目录RabbitMQ第二天 高级7 RabbitMQ 高级特性7.6 延迟队列7.6.1 延迟队列概述7.6.2 代码实现7.6.3 小结第二天 高级 7 RabbitMQ 高级特性 7.6 延迟队列 7.6.1 延迟队列概述 【重点】 延…

Leetcode 剑指 Offer II 007. 数组中和为 0 的三个数

题目难度: 中等 原题链接 今天继续更新 Leetcode 的剑指 Offer&#xff08;专项突击版&#xff09;系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i…

微信开放平台之第三方平台开发,从哪里入手?

大家好&#xff0c;我是悟空码字 疫情之下&#xff0c;最近有不少兄弟没有挺进决赛&#xff0c;半途成了小羊人&#xff0c;可谓是出师未捷身先死。话说回来&#xff0c;不管怎么样&#xff0c;尽量保护好自己&#xff0c;能越晚变羊越好。 开始说正事&#xff0c;不管是自己…

46_SDIO实验

目录 SDIO相关结构体 SDIO初始化结构体 SDIO命令初始化结构体 SDIO数据初始化结构体 硬件连接 实验源码 SDIO相关结构体 标准库函数对SDIO外设建立了三个初始化结构体&#xff0c;分别为SDIO初始化结构体SDIO_InitTypeDef, SDIO命令初始化结构体SDIO_CmdInitTypeDef和SD…

小技巧2:Python 实现阿拉伯数字转化为中文数字

大家好&#xff0c;我是Kamen Black君&#xff0c;今天给大家介绍一个小技巧&#xff1a;如何用Python 代码实现阿拉伯数字转化为中文数字。 都说光阴似箭&#xff0c;日月如梭&#xff0c;2022年的车轮很快也要驶向了终点。不知道大家在平常的生活中&#xff0c;有没有碰到过…

【Python】Beta分布详解

投硬币&#xff0c;硬币是正还是反&#xff0c;这属于两点分布的问题。 疯狂投硬币&#xff0c;正面出现的次数&#xff0c;服从二项分布&#xff1a;【Python】从二项分布到泊松分布 二项分布中&#xff0c;若特定时间内的伯努利试验次数趋于无穷大&#xff0c;那么在某一时…

【Linux】进程控制(进程创建、进程终止、进程等待、进程替换)

文章目录一、进程创建1.1 认识系统调用 fork1.2 理解 fork 的返回值1.3 写时拷贝策略二、进程终止2.1 main 函数的返回值2.2 进程退出的几种情况(&#x1f31f;)2.3 进程退出码2.4 终止正常进程&#xff1a;return、exit、_exit ⭐2.5 站在 OS 角度&#xff1a;理解进程终止三、…

RV1126笔记二十:吸烟行为检测及部署<七>

若该文为原创文章,转载请注明原文出处。 部署到RV1126,Demo测试 一、介绍 通过训练转换后,得到了RKNN模型,接下来使用rknn_model_zoo里自带的C demo来测试模型是不是可以在RV1126上运行。 C demo直接编译是编译不过的,需要自己移植. 根据C demo提供的README,可以看出…

7段数码管和打印机接口

目录 七段发光二级管显示器接口&#xff08;重点&#xff09; 打印机适配器&#xff08;重点&#xff09; 例题 补充两个芯片(了解&#xff09; 数据输出寄存器 数据输入三态缓冲器 七段发光二级管显示器接口&#xff08;重点&#xff09; 灯泡的题最难就是7段数码管。重点…

【Web开发】Python实现Web服务器(Ubuntu下调试Flask)

&#x1f37a;基于Python的Web服务器系列相关文章编写如下&#x1f37a;&#xff1a; &#x1f388;【Web开发】Python实现Web服务器&#xff08;Flask快速入门&#xff09;&#x1f388;&#x1f388;【Web开发】Python实现Web服务器&#xff08;Flask案例测试&#xff09;&a…

工厂卖家如何借助TikTok突围?

众所周知&#xff0c;TikTok已然成为全球最受欢迎的社交媒体之一&#xff0c;拥有巨大的流量池&#xff0c;对于跨境电商卖家来说&#xff0c;TikTok也是最大的站外流量来源。作为月活跃用户接近16亿的应用程序&#xff0c;TikTok的发展速度让很多社交媒体平台望尘莫及&#xf…

node.js+uni计算机毕设项目基于微信小程序寸金校园租车平台(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置&#xff1a; Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等…

rabbitmq基础6——交换器和队列web监控基础运维、备份交换机、消息确认机制、消息状态查看

文章目录一、交换器和队列的使用1.1 web监控创建交换器1.1.1 交换器参数1.1.2 备份交换器1.1.2.1 工作原理1.1.2.2 弊端情形1.2 web监控创建队列1.2.1 队列参数1.2.1.1 通用参数1.2.1.2 其他参数1.2.1.2.1 所有队列1.2.1.2.2 主队列1.2.1.2.3 仲裁队列1.2.1.2.4 流队列1.3 web监…

从原理和源码梳理Springboot FatJar 的机制

一、概述 SpringBoot FatJar 的设计&#xff0c;打破了标准 jar 的结构&#xff0c;在 jar 包内携带了其所依赖的 jar 包&#xff0c;通过 jar 中的 main 方法创建自己的类加载器&#xff0c;来识别加载运行其不规范的目录下的代码和依赖。 二、标准的 jar 包结构 打开 Java…

用html实现一个静态登陆页面-可根据需求更改样式

一、创建html文件&#xff0c;vscode下载相关插件 我们先选择一个文件夹创建login.html&#xff0c;.之前的文件命无所谓&#xff0c;.之后就必须为html或者htm。 在编辑改文件输入!且出现提示后按回车或按tab快捷生成基础代码。 然后我们下载一个可以方便我们开发的插件。 …

【计算机网络课程设计】TCP协议包自动生成工具【蒙混过关版】

文章目录引言设计要求分工安排文献查阅总体设计流程具体设计内容&#x1f315;博客x主页&#xff1a;己不由心王道长&#x1f315;! &#x1f30e;文章说明&#xff1a;TCP协议包自动生成工具&#x1f30e; ✅系列专栏&#xff1a;计算机网络 &#x1f334;本篇内容&#xff1a…

Linux系统基础——系统调用

Linux系统调用 特此说明: 刘超的趣谈linux操作系统是比较重要的参考资料&#xff0c;本文大部分内容和所有图片来源于这个专栏。 1 相关概念 程序vs进程vs命令: Linux系统上所有的操作由进程完成&#xff0c;进程的运行是动态的&#xff0c;在此之前是一个静态的程序。用户用一…