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

单向链表头插尾插

单向链表的销毁与反转

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

冒泡排

选排

链表环:

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

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

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

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

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

相关推荐
TracyCoder1237 分钟前
LeetCode Hot100(60/100)——55. 跳跃游戏
算法·leetcode
月挽清风17 分钟前
代码随想录第35天:动态规划
算法·动态规划
岛雨QA25 分钟前
链表「Java数据结构与算法学习笔记3」
数据结构·算法
Sunsets_Red32 分钟前
P8277 [USACO22OPEN] Up Down Subsequence P 题解
c语言·c++·算法·c#·学习方法·洛谷·信息学竞赛
菜鸟小九34 分钟前
redis原理篇(基本数据结构)
数据结构·数据库·redis
汉克老师41 分钟前
GESP2023年12月认证C++二级( 第三部分编程题(2) 小杨的H字矩阵)
c++·算法·矩阵·循环结构·gesp二级·gesp2级
_Li.43 分钟前
Simulink-螺旋桨动力模块
人工智能·算法·机器学习
Charlie_lll1 小时前
力扣解题-438. 找到字符串中所有字母异位词
后端·算法·leetcode
奶茶树1 小时前
【数据结构】红黑树
数据结构·c++·算法
AI周红伟1 小时前
周红伟:OpenAI 首席运营官,尚未真正看到人工智能渗透到企业业务流程中
人工智能·算法·性能优化