数组数据结构

数组也是数据呈线性排列的一种数据结构。与链表不同,在数组中,访问数据十分简单,而添加和删除数据比较耗工夫。

  • 数组的概念图。Blue、Yellow、Red 作为数据存储在数组中。


    image.png
  • 数据按顺序存储在内存的连续空间内。


    image.png
  • 由于数据是存储在连续空间内的,所以每个数据的内存地址(在内存上的位置)都可以通过数组下标算出,我们也就可以借此直接访问目标数据(这叫作“随机访问”)。


    image.png
  • 随机访问


    image.png
  • 数组的添加操作


    image.png
  • 首先,在数组的末尾确保需要增加的存储空间。


    image.png
  • 为了给新数据腾出位置,要把已有数据一个个移开。首先把 Red往后移。


    image.png
  • 然后把 Yellow往后移。


    image.png
  • 最后在空出来的位置上写入 Green。


    image.png
  • 添加数据的操作就完成了。


    image.png
  • 数组的删除操作


    image.png
  • 首先,删掉目标数据(在这里指 Green)


    image.png
  • 然 后 把 后 面 的 数 据 一 个 个 往 空 位 移。 先 把Yellow往前移。


    image.png
  • 接下来移动 Red。


    image.png
  • 最后再删掉多余的空间。这样一来 Green 便被删掉了。


    image.png

假设数组中有 n 个数据,由于访问数据时使用的是随机访问(通过下标可计算出内存地址),所以需要的运行时间仅为恒定的O(1)。
但另一方面,想要向数组中添加新数据时,必须把目标位置后面的数据一个个移开。所以,如果在数组头部添加数据,就需要 O(n) 的时间。删除操作同理。
在链表和数组中,数据都是线性地排成一列。在链表中访问数据较为复杂,添加和删除数据较为简单;而在数组中访问数据比较简单,添加和删除数据却比较复杂。

访问 添加 删除
链表
数组
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. 先来看看数组的一些基本特性 数组 数组(Array)是一种线性表数据结构。它用一组连续的内存空间,来存储一...
    后端架构进阶阅读 397评论 0 1
  • 数组的定义 数组是存储在连续内存位置的相似类型数据项的集合。 数组是C语言中的派生数据类型,它可存储原始类型的数据...
    易百教程阅读 860评论 0 0
  • 二维数组可以理解为数组的数组。二维数组组织为矩阵,可以表示为行和列的集合。 但是,创建二维数组以实现关系数据库外观...
    易百教程阅读 5,137评论 0 0
  • 什么是数据结构? 接下来我们手写一个动态数组 首先动态数组的接口设计如下: 实现代码如下: #import ...
    topCui阅读 540评论 0 0
  • 一、什么叫数组 1、数组 元素类型相同,大小相等 2、确定一个数组,需要几个参数? 3个:第一个元素的地址;数组的...
    3e1094b2ef7b阅读 265评论 0 0