数据结构 1.1 初学数据结构

数据结构的基本概念

数据结构在学什么?

如何用程序代码把现实世界的问题信息化

如何用计算机高效处理信息从而创造价值

数据:

数据元素、数据项:

数据元素——描述一个个体
数据对象——数据元素之间具有同样的性质

同一个数据对象里的数据元素,可以组成不同的数据结构。
不同的数据元素,可以组成相同的数据结构
线性数据结构——朴实无华的排行榜
网状数据结构——复杂的朋友圈
例题

数据结构的三要素 

逻辑结构

集合

各个元素同属于一个集合,别无其它关系。

线性结构

数据元素之间是一对一的关系。除了第一个元素,所有元素都有唯一的前驱,除了最后一个元素,所有元素都有唯一后继

树形结构

数据元素之间是一对多的关系。

网状结构/图结构

数据元素之间是多对多的关系

总结

数据的运算

针对于某种逻辑结构,结合实际需求,定义基本运算。

 数据的物理结构(存储结构)——如何用计算机表示数据元素的逻辑关系

顺序存储

把逻辑上相邻的元素存储在物理位置上也相邻的存储单元中,元素之间的关系由存储单元的邻接关系来体现。

链式存储

逻辑上相邻的元素在物理位置上可以不相邻,借助指示元素存储地址的指针来表示元素之间的逻辑关系。

索引存储

在存储元素信息的同时,还建立附加的索引表,索引表中的每一项称为索引项,索引项的一般形式是(关键字+地址)。

散列存储

根据元素的关键字直接计算出该元素的存储地址,又称哈希存储。

总结

1.若采用顺序存储,则各个数据元素在物理上必须是连续的,若采用非顺序存储,则各个数据元素在物理上可以是离散的。

2.数据的存储结构会影响存储空间分配的方便程度。

3.数据的存储结构会影响对数据运算的速度。

 

 结论:运算的定义是针对逻辑结构的,指出运算的功能。运算的实现是针对存储结构的,指出运算的具体操作步骤。

 总结:

补充:数据类型、抽象数据类型

数据类型

数据类型是一个值的集合和定义在此集合上的一组操作的总称。

1>原子类型:其值不可再分的数据类型。eg、bool类型、int类型

2>结构类型:其值可以再分解为若干成分(分量)的数据类型。eg、结构体

抽象数据类型

ADT,是抽象数据组织及与之相关的操作。

知识回顾

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

桥梁模板人工费多少钱?

桥梁模板是桥梁工程中不可或缺的一部分,它起到支撑和固定混凝土浇筑的作用。在桥梁建设中,模板人工费用是一个重要的成本因素。那么,桥梁模板人工费到底是多少呢?下面我们来详细了解一下。 首先,需要明确的是&#xff…

(五)正点原子STM32MP135移植——烧录

一、概述 这里用的烧录方式是使用STM32CubeProgrammer USB方式烧录 二、文件准备 还记得FIP_artifacts文件夹吗,里面存放了TF-A、optee、u-boot编译输出的东西,以及最后的fip-stm32mp135-atk-optee.bin文件 烧写程序需要准备这些: 1. …

二、互联网技术——网络协议

文章目录 一、OSI与TCP/IP参考模型二、TCP/IP参考模型各层功能三、TCP/IP参考模型与对应协议四、常用协议与功能五、常用协议端口 一、OSI与TCP/IP参考模型 二、TCP/IP参考模型各层功能 三、TCP/IP参考模型与对应协议 例题:TCP/IP模型包含四个层次,由上至…

国庆中秋特辑(八)Spring Boot项目如何使用JPA

目录 一、Spring Boot 项目使用 JPA 的步骤二、Spring Boot 项目使用 JPA 注意事项三、Spring Boot 项目使用 JPA 常用语法 Spring Boot项目如何使用JPA,具体如下 一、Spring Boot 项目使用 JPA 的步骤 添加依赖 在项目的 pom.xml 文件中添加 Spring Boot JPA 和数…

FFmpeg:打印音/视频信息(Meta信息)

多媒体文件基本概念 多媒体文件其实是个容器在容器里面有很多流(Stream/Track)每种流是由不同的编码器编码的从流中读出的数据称为包在一个包中包含着一个或多个帧 几个重要的结构体 AVFormatContextAVStreamAVPacket FFmpeg操作流数据的基本步骤 打印音/视频信息(Meta信息…

安卓 kuaishou 设备did和egid 学习分析

did和egid注册 接口 https://gdfp.ksapisrv.com/rest/infra/gdfp/report/kuaishou/android did 是本地生成的16进制 或者 获取的 android_id public static final Random f16237a new Random(System.currentTimeMillis()); public static long m19668a() { return f1623…

DeepSpeed4Science:利用先进的AI系统优化技术实现科学发现

本文转载自微软 DeepSpeed 团队官方知乎账号:zhihu.com/people/deepspeed,由微软 DeepSpeed 团队翻译自官方英文博客:Announcing the DeepSpeed4Science Initiative: Enabling large-scale scientific discovery through sophisticated AI sy…

京东商品详情数据接口用于上货,数据分析,

京东商品详情数据接口是开放平台提供的一种API接口,在电商平台中可以用于获取商品的详细信息,它是基于HTTP/HTTPS请求和JSON/ATP响应格式的RESTful API,通过调用API接口,开发者可以获取商品的标题、描述、图片等详细信息&#xff…

正向代理和反向代理

正向代理和反向代理 1.正向代理和反向代理,squid,Nginx2.正向代理主要作用:3.反向代理主要作用:4.透明代理 1.正向代理和反向代理,squid,Nginx 1.用途不同:正向代理的典型用途是为在防火墙内的…

苹果签名有多少种类之TF签名(TestFlight签名)是什么?优势是什么?什么场合需要应用到?

(一)TestFlight 能够让您:邀请内部和外部的测试人员为应用程序提供反馈。 跟踪应用程序在测试过程中发现的 bug 和用户体验问题。 收集 Crash 报告,了解应用程序在真实设备上的运行状况。 要使用 TestFlight,您可以按照…

XFTP上传文件状态出现错误的原因和解决方案

这几天有时候会出现XFTP会出现上传的时候状态出现错误的情况,我没那么在意,但是今天要传比较重要的东西,结果没办法传,我参考了这个方法,但是感觉修改用户组的权限是正确的可能解释的没那准确 之后我是直接把XFTP的登陆…

【C++】STL详解(十)—— 用红黑树封装map和set

​ ​📝个人主页:Sherry的成长之路 🏠学习社区:Sherry的成长之路(个人社区) 📖专栏链接:C学习 🎯长路漫漫浩浩,万事皆有期待 上一篇博客:【C】STL…