单向链表和双向链表的一些基本算法

单向链表头插尾插

单向链表的销毁与反转

反转原理:将头节点与后面的节点分开,然后从第一个节点开始对每个节点使用头插法

冒泡排

选排

链表环:

判断是否有环:弗洛伊德快慢指针(快指针一般是慢指针的2倍,差为自然数增长)检测法,如果快指针在遍历过程中遇到了慢指针,则有环存在

判断环入口:在相遇点,令慢指针回到头节点,然后两个指针以相同的速度移动,再次相遇点即为入口;

链表环好处:1.链表环允许从某个节点开始无限循环访问,这在需要持续遍历数据的场景中非常有用,比如任务调度、游戏循环等。

2.如果链表中有多个节点需要共享相同数据,使用环可以避免创建多个节点,节省内存。

3.对于需要处理持续流入数据的应用,环可以有效地管理数据,避免频繁的内存分配和释放。

相关推荐
LuckyRich11 分钟前
【高阶数据结构】跳表
开发语言·数据结构·c++
(lemon seed)2 分钟前
数据结构:树与二叉树(2)
数据结构·算法
ya888g3 分钟前
数据结构-图-存储-邻接矩阵-邻接表
数据结构·图论·邻接表·邻接矩阵
桃酥40335 分钟前
贪心算法day31|56. 合并区间、738. 单调递增的数字(整数与字符串的转换)、贪心刷题总结
c++·算法·leetcode·贪心算法·字符串
van叶~36 分钟前
移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——12.二叉树(习题)
开发语言·c++·算法
爱吃喵的鲤鱼38 分钟前
C++——深部解析哈希
c++·算法·哈希算法
LuckyRich11 小时前
【贪心算法】贪心算法
算法·贪心算法
MogulNemenis1 小时前
力扣100题——二维动态规划
算法·leetcode·动态规划
kingandlog1 小时前
Redis底层数据结构(详细篇)
数据结构·redis
知星小度S1 小时前
数据结构——栈和队列
c语言·数据结构·算法·链表