1. 基本概念;

线性表的链式存储结构,为了表示每个数据元素与其直接后继元素之间的逻辑关系,每个元素除了存储本身的信息外,还需要存储指示其后继的信息

单链表:

线性表的链式存储结构中,每个结点中只包含一个指针域,这样的链表叫单链表;

通过每个节点的指针域将线性表的数据元素按其逻辑次序链接在一起;

线性表(7)——链式存储_java 

概念解释:

表头结点:

链表中的第一个结点,包含指向第一个数据元素的指针以及链表自身的一些信息;

数据结点:

链表中代表数据元素的结点,包含指向下一个数据元素的指针和数据元素的信息;

尾结点:

链表中的最后一个数据结点,其下一个元素指针为空,表示无后继;

线性表(7)——链式存储_●  底层修炼_02 

 

2. 链式存储的设计与实现;

插入操作:

线性表(7)——链式存储_单链表_03

 核心代码:

newNode->next = pCurrent->next;
pCurrent->next = newNode;

删除操作:

线性表(7)——链式存储_------【C语言数据结构】_04

核心代码:

pCurrent->next = pDel->next;

 

3. 优缺点;

 优点:

无需一次性定制链表的容量;

插入和删除操作无需移动数据元素;

缺点:

数据元素必须保存后继元素的位置信息;

获取指定数据的元素操作需要顺序访问之前的元素;