算法第三十七天-旋转链表

旋转链表

题目要求

解题思路

题意:将链表中每个元素向后移动k个位置,相当于把链表的后面k%len节点移到链表的最前面。

所以本题步骤为:

1.求出链表长度;

2.找出倒数第k+1个节点

3.链表重整:将连败哦的倒数第k+1个节点和倒数第k个节点断开,并把后半部分拼接到链表的头部

1.求链表的长度

求链表长度应该是链表最基本的题型了,直接用一个指针cur,开始时指向链表的头head,一直向后移动到cur为空时,经历的链表节点数就是链表长度。

2.找出倒数第k+1个节点

思路是:

1.两个指针slowfast值距离是k,先让fast指向链表的第k+1个节点,slow指向第1个节点;

2.然后slowfast同时向后移动,当fast移动到链表的最后一个节点的时候,那么slow指向链表的倒数第k+1个节点。

3.链表重整

重整操作步骤是:

1.newHead是新链表的头部,它应该是原链表倒数第k个节点,即slow.next

2.slow需要跟slow.next断开;

3.fast是老链表的结尾,将fast.next设置为老链表的开头,实现首位相接。

可以用下面的图来帮助理解:链表是1->2->3->4->5->null,k=2。图中①是让fast指向第k+1个节点;图中②是fastslow同时后移至链表结尾,此时slow指向链表倒数第k+1个节点;图中③是链表重整的操作。

代码

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def rotateRight(self, head: ListNode, k: int) -> ListNode:
        if not head or not head.next:
            return head
        _len=0
        cur = head
        while cur:
            _len +=1
            cur=cur.next
        k %= _len
        if k == 0: return head
        slow,fast=head,head
        for i in range(k):
            fast=fast.next
        while fast.next:
            fast=fast.next
            slow = slow.next
        newHead =slow.next
        slow.next = None
        fast.next=head
        return newHead

复杂度分析

时间复杂度: O ( N ) O(N) O(N)

空间复杂度: O ( 1 ) O(1) O(1)

相关推荐
XiaoLeisj13 分钟前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jasmine_llq32 分钟前
《 火星人 》
算法·青少年编程·c#
闻缺陷则喜何志丹43 分钟前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
Lenyiin1 小时前
01.02、判定是否互为字符重排
算法·leetcode
鸽鸽程序猿1 小时前
【算法】【优选算法】宽搜(BFS)中队列的使用
算法·宽度优先·队列
Jackey_Song_Odd1 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
Watermelo6171 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
乐之者v1 小时前
leetCode43.字符串相乘
java·数据结构·算法
A懿轩A2 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组