互联网中链表是一种采用什么存储结构存储的线性表

发布时间:2021-11-22 15:35:14 作者:小新
来源:亿速云 阅读:208

这篇文章主要介绍互联网中链表是一种采用什么存储结构存储的线性表,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

链表是一种采用“链式”存储结构存储的线性表。链表的数据元素所占的存储单元地址可以是连续的,也可以是不连续的,可根据需要临时、动态地申请分配相应的存储空间,数据元素之间的逻辑关系可以用“链”来表达。

本教程操作环境:windows7系统、Dell G3电脑。

为了克服顺序表存储结构的缺点,充分利用存储空间和提高运行效率,线性表可以采用另一种存储结构——链式存储结构线性表的链式存储结构简称“链表(link list)”

一、链表概述

链表的数据元素所占的存储单元地址可以是连续的,也可以是不连续的,可根据需要临时、动态地申请分配相应的存储空间,数据元素之间的逻辑关系可以用“链”来表达。

链表的插入和删除不需要移动数据元素,只需要修改链即可实现。

链表分类:

1.按链表内存分配实现的方式分类

①动态链表

②静态链表

2.按链接方式分类

①单链表

②循环链表

③双链表

(它们均为动态链表)

二、单链表的定义

1.定义

为了表示每个数据元素ai与其直接后继数据元素ai+1之间的逻辑关系,对于每个数据元素ai,除了存储本身的信息外,还需要存储一个指示其直接后继的信息(后继的存储位置-地址)。

存储数据元素信息的域称为数据域,存储直接后继位置的域称为指针域,指针域中存储的信息称为指针或链。

这两部分信息组成数据元素ai的存储映像,称为结点

n个结点链成一个链表,即为线性表(a1,a2,a3,...,an)的链式存储结构,因为链表的每个结点中只包含一个指针域,所以称为链表

对于线性表来说,总有个头有个尾,链表也不例外。链表中指向单链表第一个结点的指针叫做头指针,整个链表的存取必须从头指针开始进行,之后的每个结点都是上个结点的后继指针指向的位置。链表的最后一个结点的指针为“(通常用NULL表示)”——空指针。

为了方便实现链表的各种运算,在单链表的第一个数据结点之前设一个类型相同的结点,该结点称为头结点。

头结点的数据域可以存储一个特殊的标志信息如链表的长度,也可以不存储任何数据。

链表的第一个数据结点和最后一个结点又称为首结点和尾结点

互联网中链表是一种采用什么存储结构存储的线性表

2.头指针和头结点的异同点

头指针:

头结点:

3.代码演示

/*线性表的单链表存储结构*/
/*结点定义*/
typedef struct Node
{
    ElemType data;
    struct Node *next;
}Node;

/*单链表定义*/
typedef struct Node *LinkList;

互联网中链表是一种采用什么存储结构存储的线性表

三、单链表的操作

1.插入操作

1)插入模拟

假设存储元素e的结点为s,将s插入到ai结点后面,如何操作?

互联网中链表是一种采用什么存储结构存储的线性表

思考:两句插入代码能否交换?

不能,如果调换过来,会导致ai+1等后面的元素无法找到,因为s的指针域没有指向ai+1的地址。

2)单链表第i个数据插入结点的算法思路

2.删除操作

1)删除模拟

假设存储元素ai的结点为q,要实现将结点q删除单链表的操作。

互联网中链表是一种采用什么存储结构存储的线性表

2)单链表删除第i个数据结点的算法思路

四、单链表结构和顺序表结构对比

存储方式:

时间性能:

①查找

②插入和删除

空间性能:

以上是“互联网中链表是一种采用什么存储结构存储的线性表”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. 线性表(1):线性表顺序存储结构的php实现
  2. 数据结构--线性表的链式存储结构

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

互联网

上一篇:如何用R语言ggplot2对科比的投篮数据进行可视化展示

下一篇:c语言怎么实现含递归清场版扫雷游戏

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》