数据结构:数组

概述

  • 数组是一种线性数据结构 ,它将相同类型 的元素存储在连续的内存空间中。
  • 资料:https://pan.quark.cn/s/43d906ddfa1b

一、数组的核心特点

  1. 连续存储:元素在内存中紧密排列,相邻元素的地址连续。
  2. 随机访问 :通过索引(下标)可直接访问任意元素,时间复杂度为 O(1)
  3. 固定大小:数组在初始化时需要指定长度,一旦创建,大小通常不可变(静态数组)。
  4. 元素同构:所有元素必须是同一数据类型(如整数、字符串等)。

二、数组的基本操作

1. 访问元素

通过索引直接访问,索引从 0 开始(部分语言如 Lua 从 1 开始)。

java 复制代码
int[] arr = {1, 2, 3, 4};
int element = arr[2]; // 访问索引 2 的元素,结果为 3
2. 更新元素

通过索引修改对应位置的值。

java 复制代码
arr[2] = 5; // 将索引 2 的元素更新为 5,数组变为 [1, 2, 5, 4]
3. 插入元素
  • 头部插入 :需将所有元素向后移动一位,时间复杂度 O(n)
  • 中间插入 :需将插入位置后的元素向后移动,时间复杂度 O(n)
  • 尾部插入 :直接在末尾添加,时间复杂度 O(1)(若数组未满)。
4. 删除元素
  • 头部删除 :需将所有元素向前移动一位,时间复杂度 O(n)
  • 中间删除 :需将删除位置后的元素向前移动,时间复杂度 O(n)
  • 尾部删除 :直接移除末尾元素,时间复杂度 O(1)
5. 遍历数组

依次访问所有元素,时间复杂度 O(n)

java 复制代码
for (int i = 0; i < arr.length; i++) {
    System.out.println(arr[i]);
}

三、数组的优缺点

优点
  • 随机访问效率高:通过索引直接定位元素,无需遍历。
  • 内存开销小:元素连续存储,无额外指针开销。
  • 实现简单:底层逻辑直观,易于理解和使用。
缺点
  • 大小固定:静态数组无法动态扩容,若元素数量超过数组长度会导致溢出。
  • 插入删除效率低:涉及元素移动,时间复杂度为 O(n)。
  • 空间浪费:若数组未填满,剩余空间无法利用。

四、数组的应用场景

  1. 需要快速访问元素的场景(如查找、排序算法)。
  2. 元素数量固定的场景(如存储一周的温度、学生的成绩等)。
  3. 底层数据结构(如哈希表、栈、队列的实现常依赖数组)。

五、数组的扩展(动态数组)

为解决静态数组大小固定的问题,许多语言提供了动态数组(如 Java 的 ArrayList、Python 的 list),其特点:

  • 支持动态扩容(通常扩容为原大小的 1.5 倍或 2 倍)。
  • 插入删除元素时自动调整容量,简化操作。
  • 牺牲部分空间换取灵活性,扩容时可能产生内存拷贝开销。

六、总结

数组是最基础的数据结构之一,核心优势是随机访问,适合处理元素数量固定且需要频繁查询的场景。若需频繁插入删除,建议使用链表等更高效的数据结构。

相关推荐
无限进步_1 小时前
C语言单向链表实现详解:从基础操作到完整测试
c语言·开发语言·数据结构·c++·算法·链表·visual studio
初夏睡觉1 小时前
循环比赛日程表 题解
数据结构·c++·算法
派大星爱吃鱼2 小时前
素数检验方法
算法
Greedy Alg2 小时前
LeetCode 72. 编辑距离(中等)
算法
xinxingrs2 小时前
贪心算法、动态规划以及相关应用(python)
笔记·python·学习·算法·贪心算法·动态规划
秋邱2 小时前
驾驭数据洪流:Python如何赋能您的数据思维与决策飞跃
jvm·算法·云原生·oracle·eureka·数据分析·推荐算法
侯小啾3 小时前
【23】C语言 左移(<<) 与 右移(>>) 位运算符在处理像素中的应用
c语言·算法·位运算·右移·左移
搂鱼1145143 小时前
(dp 优化)洛谷 P14460 寻雾启示 题解
算法·图论
_OP_CHEN3 小时前
算法基础篇:(十一)贪心算法拓展之区间问题:从重叠到覆盖的最优解艺术
算法·贪心算法