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

旋转链表

题目要求

解题思路

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

相关推荐
海兰7 分钟前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统
人工智能·学习·算法
zwenqiyu41 分钟前
P5283 [十二省联考 2019] 异或粽子题解
c++·学习·算法
wayz1141 分钟前
Momentum:TSI(真实强度指数)技术指标详解
算法·金融·数据分析·量化交易·特征工程
Queenie_Charlie41 分钟前
哈夫曼树
数据结构·c++·哈夫曼树
万事大吉CC1 小时前
Python 笔试输入模板总结
python·算法
lihao lihao1 小时前
Linux信号
开发语言·c++·算法
大白话_NOI2 小时前
【洛谷 P2249】查找(深基 13. 例 1)+ 详细分析
c++·算法
吠品2 小时前
C++实现m行n列带边框的长方形输出
算法
智者知已应修善业2 小时前
【51单片机2个外部中断显示中断历时,初始化8左移3位共阳数码管】2024-6-6
c++·经验分享·笔记·算法·51单片机
西安邮电大学2 小时前
分治算法详细讲解
java·后端·其他·算法·面试