一、概念:
- 数据结构是计算机存储、组织数据的方式
- 分为 3种:线性结构、树形结构、图形结构
- 线性结构:线性表(数组、链表、栈、队列、哈希表)
- 树形结构:二叉树(AVL树、红黑树、B树、堆、Trie、哈夫曼树、并查集)
- 图形结构:邻接矩阵、邻接表
二、线性表
-
线性表 是具有n 个相同类型元素的有限序列 (n >= 0)
-
线性表都有一个索引,通过索引来查找你要的元素
-
a1 是首节点(首元素),an 是结尾点(尾元素)
-
a1 是 a2 的前驱, a2 是 a1 的后继
-
常见的线性表有:
- 数组、
- 链表、
- 栈、
- 队列、
- 哈希表(散列表)
生活中的线性表:
- 山楂 糖葫芦
- 烤鸡翅(2个)
- 车排队
- 人排队
三、数组(Array)
- 数组是一种顺序的线性表,所有元素的内存地址是连续的
Java
int[] array = new int[] {11, 22, 33};
Swift
let array = [11, 22, 33]
在 C 语言中:数组是可以放在栈空间的。
在 Java 语言中: 数组是放在堆空间的。
在 Swift 语言中: 栈空间。
int[] array = new int[] {11, 22, 33};
-
array: 是一个局部变量,放栈空间中。
-
{11, 22, 33};
是通过 new 获取的,放堆空间。 -
数组的缺点: 在很多编程语言中,无法动态修改容量。也就是 new 出来的是几个,那就是几个。不能动态添加。
-
在实际开发中,我们希望数组的容量是可以动态改变的。