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

单向链表头插尾插

单向链表的销毁与反转

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

冒泡排

选排

链表环:

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

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

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

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

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

相关推荐
晨曦54321015 分钟前
图(Graph):关系网络的数学抽象
开发语言·算法·php
1白天的黑夜11 小时前
链表-143.重排链表-力扣(LeetCode)
数据结构·leetcode·链表
cwplh2 小时前
Manacher(马拉车算法)详解
算法
快去睡觉~8 小时前
力扣73:矩阵置零
算法·leetcode·矩阵
小欣加油9 小时前
leetcode 3 无重复字符的最长子串
c++·算法·leetcode
月盈缺11 小时前
学习嵌入式的第二十二天——数据结构——双向链表
数据结构·学习·链表
猿究院--王升11 小时前
jvm三色标记
java·jvm·算法
一车小面包12 小时前
逻辑回归 从0到1
算法·机器学习·逻辑回归
科大饭桶13 小时前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
tt55555555555513 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵