审题:
我们需要根据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)修改指针指向
算法题(56):旋转链表
被AI抢饭碗的人2025-02-04 11:31
相关推荐
森焱森1 小时前
无人机三轴稳定化控制(1)____飞机的稳定控制逻辑循环过三天1 小时前
3-1 PID算法改进(积分部分)呆瑜nuage1 小时前
数据结构——堆蓝澈11211 小时前
弗洛伊德(Floyd)算法-各个顶点之间的最短路径问题zl_dfq1 小时前
数据结构 之 【堆】(堆的概念及结构、大根堆的实现、向上调整法、向下调整法)(C语言实现)127_127_1271 小时前
2025 FJCPC 复建 VP闪电麦坤951 小时前
数据结构:二维数组(2D Arrays)凌肖战1 小时前
力扣网C语言编程题:快慢指针来解决 “寻找重复数”埃菲尔铁塔_CV算法2 小时前
基于 TOF 图像高频信息恢复 RGB 图像的原理、应用与实现NAGNIP3 小时前
一文搞懂FlashAttention怎么提升速度的?