数据结构之单链表

引言

哈喽,各位老铁。本期博主给大家带来更加精彩的内容-----单链表;前面给大家分享的顺序表它存在一个缺陷,就是我们以2倍进行增容,开辟的内存大,造成了严重的的内存资源浪费;为了避免造成内存浪费,我们就需要学习单链表。


本期内容目标

一、什么是链表?

我们都知道火车都是由车头和一节一节的车厢组成的。在运输淡季时我们可以减少车厢,在运输旺季我们可以增加车厢;其实链表的结构和火车的结构很类似;链表就是一种数据存储结构,它的结构上非连续、非顺序;链表的数据元素是由指针实现的;

相比小火车的结构,我们不难画出单链表的结构

二、实现单链表

1.创建单链表的结构:

2.实现单链表的打印:

3.实现头插:

4.实现头删:

5.实现尾插

6.实现尾删

7.查找指定节点

8.指定位置pos之前插入节点

9.删除指定位置pos节点

10.在指定位置pos之后插入节点

11.删除指定位置pos之后节点

12.销毁链表

至此就实现了一个单链表,以及实现了它的增删查改的功能;

总结

掌握链表,不仅是理解 "指针 + 结构体" 在数据结构中的经典应用,更能培养我们对非线性存储、内存动态管理的思维能力。它是后续学习双向链表、循环链表,乃至更复杂数据结构(如链表与树、图的结合)的基础,在实际开发中(如操作系统内存管理、某些缓存结构设计)也有广泛应用。通过本期对链表从 "是什么" 到 "怎么用" 的全流程学习,相信你已对这一数据结构建立了清晰且扎实的认知,不妨在实践中进一步尝试优化链表操作,或探索其与其他数据结构的联动吧!


行文至此,本期要给大家分享的内容就到这里了;新的内容也正在努力创作中,如果你觉得博主的文章对你有帮助三连支持一下;你的支持是我持续创作最大的动力;我们下期不见不散。

相关推荐
papership7 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826527 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa7 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!7 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
Beginner x_u8 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
丑八怪大丑8 小时前
Java数据结构与集合源码
数据结构
一个爱编程的人16 小时前
一个数是不是素数
数据结构·算法
忡黑梨16 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
地球资源数据云17 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
AI人工智能+电脑小能手17 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index