一、顺序存储结构——顺序表
顺序表是用一段地址连续的存储单元依次存储线性表的数据元素。由于线性表中每个数据元素类型相同,所以通常用一维数组来存储线性表,把线性表中相邻的元素存储在数组中相邻的位置。用数组存放顺序表,这意味着我们要确定数组的长度,分配固定长度的数组空间。
①特点:按位查找算法的时间复杂度为O(1),按值查找的平均时间性能是O(n),插入删除操作的平均时间性能是O(n),适用于频繁查找却很少进行插入和删除操作,或其操作和“数据元素在线性表中的位置”密切相关。
②优点:随机访问较快,创建简单。
③缺点:插入和删除需要移动大量的元素;表的容量难以确定;存储空间的使用比率低等。
二、链接存储结构
1.单链表
单链表是用一组任意的存储单元存放线性表的元素,无需事先分配存储空间,存储单元可以连续也可以不连续。
①特点:每一个结点有着数据域和指针域,指针域指向下一个结点。查询时的平均时间性能是O(n),插入删除操作的平均时间性能是O(n),适用于频繁进行增添或删除元素操作。
②优点:结构简单,需要的存储空间小,能动态存储分配,插入和删除也无需移动元素,效率高。
③缺点:只能从表头开始依次向后扫描,直到找到那个特定的位置,查找存取效率低。
2.循环链表
循环链表是将终端结点的指针域由空指针改为指向头结点,就使得整个单链表形成一个环,简称循环链表。
①特点:从链表的任一结点出发,可扫描到其他结点,找到开始的节点平均时间性能是O(n)
②优点:无须增加存储量,从循环链表中任一结点出发,就可扫描到其他结点,增加链表的灵活性。
③缺点:相比单链表,循环链表中没有明显的尾端,容易造成死循环,需要格外注意循环条件。
3.双向链表
双向链表它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。
①特点:从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。
②优点:可以在结点前面或者后面插入和删除操作,可以删除前驱和后继。
③缺点: 多了前驱指针域,加大了在结构上内存开销。
三、线性表的其他存储方法
1.静态链表
静态链表是用数组来表示单链表,用数组元素的下标来模拟单链表的指针。
①特点:每个数组元素由两个域组成:data域存放数据元素,next域存放该元素的后继元素所在的数组下标。
②优点:便于数据的插入和删除操作,只需要修改游标,不需要移动表中的元素,从而改进了插入和删除操作需要移动大量元素的缺点。
③缺点:没有解决连续存储分配带来的表长难以确定的问题。
2.间接寻址
间接寻址是将数组和指针结合起来的一种方法。
①特点:将数组中存储数据元素的单元改为存储指向该元素的指针,它将数组中存储数据元素的单元改为存储指向该元素的指针。
②优点:保持了顺序表随机存取的优点,同时改进了插入和删除操作的时间性能
③缺点:没有解决连续存储分配带来的表长难以确定的问题
四、总结
线性表的顺序存储和链接存储各有其优点,不能笼统地说哪种存储结构更好,只能根据实际问题的需要,并对各方面的优缺点加以综合,才能最终选定比较适宜的存储结构。通过这几次的线性表的实验让我更加的了解线性表的几种主要的存储结构,希望在接下来的学习中能够再进一步,,取得更加好的成绩。