数据结构(五)单链表专题

在开始之前,我先来给大家讲一下顺序表与链表的区别:

它们在堆上存储的差异:

我们可以很容易的知道,循序表是连续的有序的,但链表是杂乱的,它们通过地址彼此联系起来。

1. 链表的概念及结构

概念:链表是⼀种物理存储结构上⾮连续、⾮顺序的存储结构,数据元素的逻辑顺序是通过链表?
 中的指针链接次序实现的。

链表的结构跟⽕⻋⻋厢相似,淡季时⻋次的⻋厢会相应减少,旺季时⻋次的⻋厢会额外增加⼏节。只需要将⽕⻋⾥的某节⻋厢去掉/加上,不会影响其他⻋厢,每节⻋厢都是独⽴存在的。 

⻋厢是独⽴存在的,且每节⻋厢都有⻋⻔。想象⼀下这样的场景,假设每节⻋厢的⻋⻔都是锁上的状态,需要不同的钥匙才能解锁,每次只能携带⼀把钥匙的情况下如何从⻋头⾛到⻋尾?
最简单的做法:每节⻋厢⾥都放⼀把下⼀节⻋厢的钥匙。

在链表⾥,每节“⻋厢”是什么样的呢?

与顺序表不同的是,链表⾥的每节"⻋厢"都是独⽴申请下来的空间,我们称之为“结点/节点”?
节点的组成主要有两个部分:当前节点要保存的数据和保存下⼀个节点的地址(指针变量)。
图中指针变量?plist保存的是第⼀个节点的地址,我们称plist此时“指向”第⼀个节点,如果我们希
望plist“指向”第⼆个节点时,只需要修改plist保存的内容为0x0012FFA0

为什么还需要指针变量来保存下⼀个节点的位置? 

链表中每个节点都是独⽴申请的(即需要插⼊数据时才去申请⼀块节点的空间),我们需要通过指针变量来保存下⼀个节点位置才能从当前节点找到下⼀个节点。

结合前⾯学到的结构体知识,我们可以给出每个节点对应的结构体代码:
假设当前保存的节点为整型:

struct SListNode
{
int data; //节点数据
struct SListNode* next; //指针变量⽤保存下⼀个节点的地址
};
struct SListNode*是一个结构体指针

那我们现在开始进入正题吧。

2.链表的打印

给定的链表结构中,如何实现节点从头到尾的打印?

2.1节点的申请

由于我们不需要扩容,所以就使用 malloc。

2.2节点的链接

2.3打印过程

打印函数:

定义一个新的 plist 把第一个节点传过去。

我们来看一下结果:

大家肯定会有疑问但是不用着急,我来为大家一点一点解释清楚。

先来讲一下打印过程:

我们来看这段代码:  

pcur  的运行过程:我们随便给几个地址更直观的来观察。

关键点拨:pcur刚开始保存第一个节点0x100, 此时指向第一个节点。

                  pcur = pcur -> next ;   此时 next 保存的是第二个节点的。

                  把第二个节点的地址赋给了 pcur 使向后移动指向第二节点。

                 以此类推这个过程就实现了节点的打印。

 

以上是链表的打印过程,现在我们来实现链表。

3.链表的实现

3.1 链表的头插和尾插

头插和尾插(顺序表)我们在上一篇博客中有讲解感兴趣的同学可以去看看,把链接放在这了。

CSDN

3.1.1尾插

 3.1.1.1链表不为空

我们老样子画图来展示

红色方块是我们插入的内容 ,那么怎么实现呢?

我们需要改变走向,使3后面的指向4,让4再去指向空。

3.1.1.2链表为空

我们之间创建一个4,让4的next指向NULL。

代码如下:

为什么是空链表呢?

来检查一下:调试,监视窗口。

在进入测试代码之前一切正常,我们继续。

问题找到了,我们发现 plist 没有改变,还是空指针。

我们来看看到底是哪出了问题:

我们发现--plist中存的是值并不是地址。(plist中放的是NULL)但我们接收时使用的是指针,所以就会出现问题。

修改如下:由于需要传地址,又因为plist是一个一级指针,所以接收的时候应使用二级指针来接收。

我们再来运行一次

到这里就没有问题了。

尾插完了我们接着继续来头插

3.1.2头插

3.1.2.1链表不为空

3.1.2.2;链表为空 

代码如下:

4.单链表的实现

typedef int SLTDataType;
typedef struct SListNode
{
SLTDataType data; //节点数据
struct SListNode* next; //指针保存下⼀个节点的地址
}SLTNode;
void SLTPrint(SLTNode* phead);
//头部插⼊删除/尾部插⼊删除
void SLTPushBack(SLTNode** pphead, SLTDataType x);
void SLTPushFront(SLTNode** pphead, SLTDataType x);
void SLTPopBack(SLTNode** pphead);
void SLTPopFront(SLTNode** pphead);
//查找
SLTNode* SLTFind(SLTNode* phead, SLTDataType x);
//在指定位置之前插⼊数据
void SLTInsert(SLTNode** pphead, SLTNode* pos, SLTDataType x);
//删除pos节点
void SLTErase(SLTNode** pphead, SLTNode* pos);
//在指定位置之后插⼊数据
void SLTInsertAfter(SLTNode* pos, SLTDataType x);
//删除pos之后的节点
void SLTEraseAfter(SLTNode* pos);
//销毁链表
void SListDesTroy(SLTNode** pphead);

5. 链表的分类 

链表的结构⾮常多样,以下情况组合起来就有8种(2x2x2)链表结构:

链表说明:

虽然有这么多的链表的结构,但是我们实际中最常⽤还是两种结构: 单链表 双向带头循环链表.
 1.⽆头单向⾮循环链表:结构简单,⼀般不会单独⽤来存数据。实际中更多是作为其他数据结
 构的⼦结构,如哈希桶、图的邻接表等等。另外这种结构在笔试⾯试中出现很多。
 2.带头双向循环链表:结构最复杂,⼀般⽤在单独存储数据。实际中使⽤的链表数据结构,都
 是带头双向循环链表。另外这个结构虽然结构复杂,但是使⽤代码实现以后会发现结构会带
 来很多优势,实现反⽽简单了,后⾯我们代码实现了就知道了。 

今天的博客就到这里了

后续会持续更新数据结构的相关知识

请大家持续关注

感谢你的观看。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/570584.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高效解决Visual Studio无法识别到自定义头文件

文章目录 问题解决方案 问题 说明你没有好好配置项目属性 解决方案 把头文件都集中存放到一个文件夹里 之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路…

掌握ES6的箭头函数:深入了解其实用性与规则

引言 ES6(ECMAScript 2015)引入了箭头函数,这是一种新的函数声明方式,它改变了我们编写JavaScript代码的方式。箭头函数提供了更简洁、更直观的语法,并且具有一些独特的特性和行为。本文将深入探讨箭头函数的规则、用…

C语言中位运算介绍

在C语言中,位运算是一种对二进制位进行操作的运算方式,它可以对数据的二进制表示进行位级别的操作,包括按位与、按位或、按位异或、按位取反等。位运算常用于处理底层数据结构、优化代码性能以及实现各种算法。本文将深入介绍C语言中的位运算…

C语言实现顺序表(增,删,改,查)

目录 一.概念: 1.静态顺序表:使用定长数组存储元素。 2.动态顺序表:使用动态开辟的数组存储。 二.顺序表的实现: 1.顺序表增加元素 1.检查顺序表 2.头插 3.尾插 2.顺序表删除元素 1.头删 2.尾删 3.指定位置删 3.顺序表查找元素 …

软考高级架构师:云计算架构概念和例题

一、AI 讲解 云计算架构是支撑云计算服务运作的基础,它涵盖了从物理资源到用户接口的多个层面。具体可分为用户访问层、管理层、应用层、平台层和资源层。 下面是对每一层的通俗解释和示例。 层级功能示例用户访问层用户通过网络访问云服务的接口层,如…

webpack练习之手写loader

手写一个style-loader来把样式文件插入head里面,准备工作 vue webpack就自己弄了,webpack的一些配置也自己配置好 一、创建index.css文件 .box{width: 100px;height: 100px;background-color: red; }然后在vue的main.js文件中引入它 二、创建自定义l…

Redis入门三(主从复制、Redis哨兵、Redis集群、缓存更新策略、缓存穿透、缓存击穿、缓存雪崩)

文章目录 一、主从复制1.单例redis存在的问题2.主从复制是什么?3.主从复制的原理4.主从搭建1)准备工作2)方式一3)方式二 5.python中操作1)原生操作2)Django的缓存操作 二、Redis哨兵(Redis-Sent…

Kibana的安装(Linux版)

Kibana是一个针对Elasticsearch的开源分析及可视化平台,用来搜索、查看交互存储在Elasticsearch索引中的数据。使用Kibana,可以通过各种图表进行高级数据分析及展示。 Kibana让海量数据更容易理解。它操作简单,基于浏览器的用户界面可以快速创…

[GXYCTF2019]StrongestMind

web请求类题目,要求1000次 import requests from bs4 import BeautifulSoup import time urlhttp://ad7bc925-bc7a-4881-8a75-9045b60d4ab2.node5.buuoj.cn:81/index.php srequests.session() #维持会话 datas.get(url) for i in range(1001):soupBeautifulSoup(d…

记录些LLM相关的知识

MMR MMR(Maximum Marginal Relevance)最大边际相关性是一种用于信息检索和推荐系统的算法,它的目的是在推荐项目时平衡相关性和多样性。MMR算法旨在找出与用户查询最相关的同时又足够多样化的项目集合。 在信息检索领域,MMR算法通…

10.IO流(一)

文章目录 IO流一、File1.创建对象1.1 创建File类的对象1.2 注意1.3 绝对路径、相对路径 2.常用方法1:判断文件类型、获取文件信息3.常用方法2:创建文件、删除文件3.1 File类创建文件的功能3.2 File类删除文件的功能 4.常用方法3:遍历文件夹4.1 File类提供的遍历文件夹的功能4.2…

jupyter notebook导出含中文的pdf(LaTex安装和Pandoc、MiKTex安装)

用jupyter notebook导出pdf时,因为报错信息,需要用到Tex nbconvert failed: xelatex not found on PATH, if you have not installed xelatex you may need to do so. Find further instructions at https://nbconvert.readthedocs.io/en/latest/install…