• 首页
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案
目录

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

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

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

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

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

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

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

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

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

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

延伸阅读:

二、线性表基本架构

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

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

package LinerList;

public interface ListInterface<T> {   

    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输出   

}

相关文章