1. 线性表
定义:线性表( linear list )是n个具有相同特性的数据元素的有限序列。线性表是⼀种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串...
相同特性包括逻辑结构和物理结构。
逻辑结构:认为想象出来的一种结构。
物理结构:数据在内存中的存储形式。
线性表在逻辑上是线性结构,也就说是连续的⼀条直线。但是在物理结构上并不⼀定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。
2. 顺序表(SeqList)/(sequence:顺序的,list:列表)
2.1 概念与结构
概念:顺序表是用⼀段物理地址连续的存储单元依次存储数据元素的线性结构,⼀般情况下采用数组存储。
顺序表和数组的区别?
顺序表的底层结构是数组,对数组的封装,实现了常用的增删改查等接
对于线性表来说,逻辑结构都是线性的,物理结构不一定是线性的。
顺序表的底层结构就是数组。
顺序表是对数组(增加、删除、修改、查找数据)来实现的,也就是对数组进行封装得到的。
2.2 分类
顺序表分为静态顺序表和动态顺序表。
2.2.1静态顺序表
概念:使用定长数组存储元素。
静态顺序表缺陷:空间给少了不够用,给多了造成空间浪费
2.2.2 动态顺序表
2.3 动态顺序表的实现
包括对顺序表的增删查改。
定义三个文件,如下:
其中.h结尾的头文件起着相当于目录的作用。
动态顺序表实现的前提:
1.定义顺序表的结构
2.顺序表的初始化
3.顺序表的销毁
接下来就是对顺序表中数据的插入
顺序表数据的插入包含头插(SLPushFront)和尾插(SLPushBack),接下来先介绍尾插。
尾插包含两种情况:
1.空间充足
2.空间不足
这时capacity表示的是空间容量(10),再插入数据后插入到size指向的位置(因为数组的下标是从0开始的),插入之后size要+1,因为size是有效数据个数。
空间不足的时候这时的capacity大小为3,再插入一个数据是肯定插不下的,这时就要对空间进行增容了(realloc),但要如何增容呢?
其实增容是成倍数的增加,比如2、3、4.....
但很多人又有疑问了,为什么不一次增加一个呢?这样不就没有空间浪费了吗?
其实增容的操作本身就有一定的性能的消耗,若频繁的增容会导致程序效率低下。
增容分两种情况:
1.连续空间足够,直接扩容
2.连续空间不够
1)重新找一块地址,分配足够的空间
2)拷贝数据到新的地址
3)销毁旧地址