数组

作者: Tlion | 来源:发表于2019-02-25 19:51 被阅读0次

1. 什么是数组

数组(Array)是一种 线性表 数据结构。它用一组 连续的内存空间,来存储一组具有相同类型的数据。

线性表:数据排列成线性结构,具有前后关系,链表、栈、队列也都是线性表结构

非线性表:数据之间不是简单的前后关系,树、图等是非线性表结构

内存连续,类型相同:正是这个特性使得数组可以支持 随机访问,因为可以通过类型 + 下标来获得随机访问的元素的真实物理地址,但这使得在数组中 删除、插入 一个元素需要大量的移动元素操作

数组内存地址计算:a[i]_address = a[0]_address + i*data_type_size

在数组不是必须有序的情况下,向数组中某个位置插入元素,可以将原本该位置的元素放到数组末尾,然后将新元素放到该位置,这样复杂度只有 O(1)

2. 数组的优缺点

优点:

  1. 支持根据下标随机访问

缺点:

  1. 插入、删除慢,需要平均 O(n) 的时间复杂度(需要做大量的数据迁移-内存空间必须连续)

相关文章

  • 数组

    数组数组数组数组数组数组数组数组数组

  • JavaScript - 5.数组<增删改查>

    数组 Array 数组 - 增 数组 - 删 / 改 数组 - 查 数组 - 自动 toString() 数组 -...

  • PHP数组使用

    数组定义 数组增、删、改 数组查询 数组排序 数组合并、分割 数组比较、去重复 数组长度 数组遍历 数组转换 其他...

  • 》》》PHP初入---(三)

    数组定义 1.索引数组:数组下标是整型的 声明数组: 访问数组: count(数组)--获取数组长度 查看数组所有...

  • JavaScript中数组的常用操作

    数组的遍历 数组的映射 数组的简化 数组的连接 获取数组的片段 数组的拷贝 查找数组 数组去重

  • JavaSE之数组

    六、数组 目录:数组概述、数组声明创建、数组使用、多维数组、Array类、稀疏数组 1.什么是数组 数组的定义:数...

  • Shell数组、关联数组

    数组 定义数组 获取数组 关联数组 定义关联数组 获取关联数组

  • 学习Java第五天

    数组是多个数据的集合 数组的语法 数组元素类型【】 数组名; 多维数组: 数组元素类型【】【】 数组名; 多维数组...

  • php基础精粹

    PHP php数组 php数组之索引数组初始化 PHP数组之索引数组赋值 PHP数组之访问索引数组内容 PHP数组...

  • C语言的惯用集

    数组部分 数组部分 清空数组a 把数据读进数组a 对数组a求和

网友评论

      本文标题:数组

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