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

旋转链表

题目要求

解题思路

题意:将链表中每个元素向后移动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)

相关推荐
木子.李3472 小时前
排序算法总结(C++)
c++·算法·排序算法
闪电麦坤953 小时前
数据结构:递归的种类(Types of Recursion)
数据结构·算法
小熊猫写算法er4 小时前
终极数据结构详解:从理论到实践
数据结构
Gyoku Mint4 小时前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
纪元A梦4 小时前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法
px不是xp5 小时前
山东大学算法设计与分析复习笔记
笔记·算法·贪心算法·动态规划·图搜索算法
-qOVOp-5 小时前
408第一季 - 数据结构 - 栈与队列的应用
数据结构
枫景Maple6 小时前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
鑫鑫向栄6 小时前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划