数据结构到底是什么?

简介: “数据结构是数据对象,以及存在于该对象的实例和组成实例的数据元素之间的各种联系。这些联系可以通过定义相关的函数来给出。” ——《数据结构、算法与应用》

数据结构到底是什么?


什么是数据结构?


“数据结构是数据对象,以及存在于该对象的实例和组成实例的数据元素之间的各种联系。这些联系可以通过定义相关的函数来给出。” ——《数据结构、算法与应用》


“数据结构是 ADT (抽象数据类型 Abstract Data Type)的物理实现。” ——《数据结构与算法分析》


“数据结构(data structure)是计算机中存储、组织数据的方式。通常情况下,精心选择的数据结构可以带来最有效率的算法。” ——中文维基百科


  • 以上是三个地方对于数据结构的官方解释,不利于理解,所以换种方法,帮助理解数据结构:数据结构就是在计算机中,存储和组织数据的方式。


  • 解决问题方法的效率,跟数据的组织方式有关。计算机中存储的数据量庞大,种类很多。


常见的数据结构


  • 常见的数据结构较多:

1.png

-   每一种都有其对应的应用场景,`不同的数据结构` 的`不同操作`性能是不同的。

生活中的数据结构


  • 图书的摆放:为了更加方便的插入和搜索书籍,需要合理的组织数据,并且通过更加高效的算法插入和查询数据。
  • 快递:采用合理的数据结构摆放快递,快递员就可以很快的找到快递。
  • 如果北京到杭州有一座 1000km 高架桥,有一天其中 1m 出现故障,那么怎么可以快速定位出故障的位置(线性查找需要 50w 次,二分查找法需要 20 次)。


数据结构


  • JavaScript 的数组就是 API 的调用。


  • 补充:普通语言的数组封装(比如 Java 的 ArrayList )
  • 常见语言的数组不能存放不同的数据类型,因此所有在封装时通常存放在数组中的是 Object 类型。
  • 常见语言的数组容量不会自动改变(需要进行扩容操作)。
  • 常见语言的数组进行中间插入和删除操作性能比较低。
相关文章
|
存储 索引
数据结构各结构特点(数组、链表、栈、队列、树)(上)
数据结构各结构特点(数组、链表、栈、队列、树)
425 0
|
存储 自然语言处理 IDE
通义灵码初识
讲述什么是通义灵码、适用环境、基本操作
|
SQL 分布式计算 算法
Hive关联时丢失数据问题和常用的Hive SQL参数设置
针对结果的发生,本文从以下方面分析原因及提供解决方案: - 右表没有匹配的数据 - 关联键数据类型不匹配 - 受count列null值影响 - Hive版本问题,在某些版本中,左连可能导致右表为null - 数据倾斜 并在文末附属了`Hive SQL常用参数设置`的说明。
Hive关联时丢失数据问题和常用的Hive SQL参数设置
|
存储 传感器 数据可视化
3D目标检测数据集 KITTI(标签格式解析、3D框可视化、点云转图像、BEV鸟瞰图)
本文介绍在3D目标检测中,理解和使用KITTI 数据集,包括KITTI 的基本情况、下载数据集、标签格式解析、3D框可视化、点云转图像、画BEV鸟瞰图等,并配有实现代码。
3555 1
|
12月前
|
Linux Shell 异构计算
在linux上部署yolov5和安装miniconda3
这篇文章介绍了在Linux系统上部署YOLOv5并安装Miniconda3的步骤,包括使用wget命令下载Miniconda安装脚本、安装Miniconda、初始化Conda环境、添加镜像源等。
708 3
在linux上部署yolov5和安装miniconda3
|
12月前
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。
|
12月前
|
SQL 数据库 索引
SQL语句实现投影连接:方法与技巧详解
在SQL数据库查询中,投影和连接是两个核心概念
|
12月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
分布式计算 API Apache
Spark与Elasticsearch的集成与全文搜索
Spark与Elasticsearch的集成与全文搜索
|
12月前
|
前端开发 测试技术 数据库
代购系统搭建涉及到哪几方面❓
代购系统搭建涉及前端开发、后端管理系统、数据库设计与实现、代购流程设计与实现及其他方面。前端需响应式设计、合理布局、美观样式和良好交互;后端涵盖商品、订单和用户管理;数据库设计高效查询;代购流程确保操作简便;还需支持多语言、数据安全及系统测试与维护。