算法题(56):旋转链表

审题:

我们需要根据k的大小把链表向右移动对应次数,并返回移动后的链表的头结点指针

思路:
根据提示中的数据大小我们发现:k的值可以远大于节点数。

也就是说我们对链表的操作存在周期,如果k%len==0,说明我们就不用做任何操作了,而如果k%len!=0,我们需要操作的次数就是运算后的余数。

第一步:确定需要操作的次数

(1)写个getlen方法

(2)利用k=k%len求出需要操作的次数k

实际上,我们如果真的一次次去操作链表会发现一个问题:我们如何更新标签?

因为每次进行移动我们都需要头指针,尾指针

问题出在尾指针又需要我们每次都去遍历一次链表来找。

那么我们有没有办法可以只进行一次操作呢?

我们只需要找到移动k次后的头结点,该头结点的前一个节点,以及一开始的链表的尾结点即可

第二步:找到三个关键节点

第三步:修改指针指向

最后是特殊情况处理

解题:

(1)确定需要操作的次数

getlen的逻辑就是遍历链表,每次遍历到一个节点就让num++,直到遍历到空指针

特殊情况处理:

1.当链表为空的时候len为0,由于0不能做被除数,所以这里k%0会出问题,我们要提前截断这种情况

2.当k取余后为0,说明不用我们操作,直接返回head

(2)找到三个关键节点

疑问:为什么prvleft需要指向一个哨兵节点?

若他指向head先,而我们的left最终也是head,就会因为逻辑问题出错

(3)修改指针指向

61. 旋转链表 - 力扣(LeetCode)

相关推荐
ShiinaMashirol4 小时前
代码随想录打卡|Day27(合并区间、单调递增的数字、监控二叉树)
java·算法
wuqingshun3141596 小时前
蓝桥杯 5. 交换瓶子
数据结构·c++·算法·职场和发展·蓝桥杯
Demons_kirit6 小时前
Leetcode 2845 题解
算法·leetcode·职场和发展
adam_life7 小时前
http://noi.openjudge.cn/——2.5基本算法之搜索——200:Solitaire
算法·宽搜·布局唯一码
我想进大厂7 小时前
图论---朴素Prim(稠密图)
数据结构·c++·算法·图论
我想进大厂7 小时前
图论---Bellman-Ford算法
数据结构·c++·算法·图论
AIGC大时代8 小时前
高效使用DeepSeek对“情境+ 对象 +问题“型课题进行开题!
数据库·人工智能·算法·aigc·智能写作·deepseek
lkbhua莱克瓦248 小时前
用C语言实现——一个中缀表达式的计算器。支持用户输入和动画演示过程。
c语言·开发语言·数据结构·链表·学习方法·交友·计算器
CODE_RabbitV8 小时前
【深度强化学习 DRL 快速实践】近端策略优化 (PPO)
算法
Wendy_robot9 小时前
【滑动窗口+哈希表/数组记录】Leetcode 438. 找到字符串中所有字母异位词
c++·算法·leetcode