美文网首页
数组数据结构

数组数据结构

作者: 程序小白菜 | 来源:发表于2020-01-21 16:06 被阅读0次

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

  • 数组的概念图。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) 的时间。删除操作同理。
在链表和数组中,数据都是线性地排成一列。在链表中访问数据较为复杂,添加和删除数据较为简单;而在数组中访问数据比较简单,添加和删除数据却比较复杂。

访问 添加 删除
链表
数组

相关文章

  • 数据结构:数组

    00数据结构与算法分析:大纲01数据结构:数组02数据结构:链表03数据结构:栈03数据结构:队列 数组 数组是一...

  • 重温:数据结构与算法 - 03数组

    数据结构与算法之美 - 数组 数据结构与算法之美-学习大纲 什么数组? 数组是一种 线性表 数据结构。它用一组 连...

  • 关于HashMap,这篇文章已经总结很详细了

    HashMap的底层数据结构? HashMap 是我们非常常用的数据结构,由 数组和链表组合构成 的数据结构。数组...

  • 剑指offer阅读(一)

    数据结构 面试题二: 数组 数组是一种最简单的数据结构,占据一块连续的数据结构并按照顺序存储数据。创建数组时,我们...

  • HashMap原理基础

    数据结构分析 数据结构:数组+链表(或红黑树) 数组:Entry implements Map.Entr...

  • Kotlin数据容器(1)✔️数组

    对象数组基本数据类型数组   数据容器是基于某种数据结构的,常见的数据结构有数组 (Array)、集 (Set)、...

  • ArrayList、LinkedList、Vector的区别

    1.从存储数据结构分析 ArrayList:数组 Vector:数组 LinkedList:双向链表数组:(数组属...

  • ArrayList和LinkedList——数组VS链表

    一、数据结构 1.1 数组 ArrayList是一种数组类型的数据结构,数组是内存中一段地址连续的空间。 我们使用...

  • ConcurrentHashMap 1.7和1.8的区别

    一、1.7中数据结构 Segment数组 + HashEntry数组 + Reentrantlock Segmen...

  • 11.11

    今天把数组方面的数据结构题目刷了10多道。 明日计划: 学完数组方面的数据结构题目 学习单链表的数据结构题目

网友评论

      本文标题:数组数据结构

      本文链接:https://www.haomeiwen.com/subject/viyezctx.html