全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

线性表、顺序表和双向链表的区别是什么?

发布时间:2023-10-11 09:45:11
发布人:xqq

一、线性表、顺序表和双向链表的区别

线性表是具有相同数据类型的n(n>0)个数据元素的有限序列。线性表的顺序存储结构就是顺序表,链式存储结构就是链表,链表又包括单向链表、双向链表、循环链表、静态链表等。

顺序表可以实现随机访问,随机存取,占用连续的存储空间,空间利用率较高,但是顺序表的插删,需要移动多个元素。

链表只能顺序访问,占用额外的存储空间存储元素间的关系,空间利用率更低,存储空间不一定连续,但是链表的插删不需要移动多个元素。

双向链表解决了单向链表只能从前向后遍历,实现了可以通过某结点访问它的直接前驱、直接后继。

线性表是一种抽象的数据类型,表中的元素的数据类型相同,首结点没有前驱结点,只有一个后继结点,尾结点没有后继结点,只有一个前驱结点,其它结点只有一个前驱和一个后继结点。

顺序表指的是线性表用顺序存储方式(一般用数组)保存。

双向链表指的是线性表用双向链表的方式存储。

延伸阅读:

二、线性表基本架构

对于一个线性表来说。不管它的具体实现如何,但是它们的方法函数名和实现效果应该一致(即使用方法相同、达成逻辑上效果相同,差别的是运行效率)。线性表的概念与Java的接口/抽象类有那么几分相似。非常知名的就是List的Arraylist和LinkedList,List是一种逻辑上的结构,表示这种结构为线性表,而ArrayList,LinkedList更多的是一种物理结构(数组和链表)。

所以基于面向对象的编程思维,我们可以将线性表写成一个接口,而具体实现的顺序表和链表的类可以实现这个线性表的方法,提高程序的可读性,还有一点比较重要的,记得初学数据结构与算法时候实现的线性表都是固定类型(int),随着知识的进步,我们应当采用泛型来实现更合理。至于接口的具体设计如下:

package LinerList;

public interface ListInterface {   

    void Init(int initsize);//初始化表

    int length();

    boolean isEmpty();//是否为空

    int ElemIndex(T t);//找到编号

    T getElem(int index) throws Exception;//根据index获取数据

    void add(int index,T t) throws Exception;//根据index插入数据

    void delete(int index) throws Exception;

    void add(T t) throws Exception;//尾部插入

    void set(int index,T t) throws Exception;

    String toString();//转成String输出   

}

#it技术干货

相关文章

数据结构s->较好是什么意思?

数据结构s->较好是什么意思?

2023-10-11
c++的数据结构中,某个结点root的表示中!root和root!=nullptr的区别在哪?

c++的数据结构中,某个结点root的表示中!root和root!=nullptr的区别在哪?

2023-10-11
java中常见的数据类型有哪些?

java中常见的数据类型有哪些?

2023-10-11
线性表中的随机存取(读写)是什么意思?

线性表中的随机存取(读写)是什么意思?

2023-10-11

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取