力扣24.两两交换链表中的节点、25.K个一组反转链表

24.两两交换链表中的节点

一、迭代

思路:

与之前的类似,创建一个虚拟节点,来统一处理方式,然后就是按照一般的链表思路进行操作,重要的是自己在草稿本上画好图,分清楚什么时候两个节点之间的连接断了,先变动什么节点后变动什么节点。

代码:

python 复制代码
class Solution:
    def swapPairs(self, head: Optional[ListNode]) -> Optional[ListNode]:
        if not head:
            return head
        if not head.next:
            return head
        
        dum = ListNode(next=head)
        pre = dum
        cur = dum.next

        while pre and cur and pre.next and cur.next:
            pre.next = cur.next
            cur.next = pre.next.next
            pre.next.next = cur
            pre = cur
            if cur:
                cur = cur.next

        return dum.next

复杂度分析:

  • 时间复杂度:O(n),其中 n 是链表的节点数量。需要对每个节点进行更新指针的操作。

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

二、递归

递归三部曲:

1、参数及返回值:参数已确定,返回值为交换后的链表头节点(即节点2)

2、递归终止条件:链表中没有节点,或者链表中只有一个节点,此时无法进行交换。

3、递归内操作:确定三个节点后,节点1指向由节点3返回的交换后的节点,节点2指向节点1

代码:

python 复制代码
class Solution:
    def swapPairs(self, head: Optional[ListNode]) -> Optional[ListNode]:
        if not head or not head.next:
            return head
        
        node1 = head
        node2 = head.next
        node3 = node2.next

        node1.next = self.swapPairs(node3)
        node2.next = node1

        return node2

25.K个一组反转链表

思路:

我自己没写出来,大概知道是用反转列表来操作但死脑不想再动了...不太好解释,建议看了代码自行进行一个循环的模拟就能够理解链表指向是如何修改的了

参考:

https://leetcode.cn/problems/reverse-nodes-in-k-group/solutions/1992228/you-xie-cuo-liao-yi-ge-shi-pin-jiang-tou-plfs

代码:

python 复制代码
class Solution:
    def reverseKGroup(self, head: Optional[ListNode], k: int) -> Optional[ListNode]:
        # 统计节点个数
        n = 0
        cur = head
        while cur:
            n += 1
            cur = cur.next

        p0 = dum = ListNode(next=head)
        pre = None
        cur = head

        # 每 k 个一组处理
        while n >= k:
            n -= k
            for _ in range(k):
                temp = cur.next
                cur.next = pre
                pre = cur
                cur = temp

            # 只能说自行模拟一下,以[1, 2, 3, 4], k=2为例在纸上画一下,就知道是如何修改链表的指向的了
            temp = p0.next
            temp.next = cur
            p0.next = pre
            p0 = temp

        return dum.next
相关推荐
装不满的克莱因瓶17 小时前
掌握语义分割经典模型 FCN——从像素分类到端到端分割的奠基之作
人工智能·python·深度学习·算法·机器学习·分类·数据挖掘
学计算机的计算基17 小时前
链表算法上篇:LeetCode 206/234/141/142/160/21 题解与易错点
java·笔记·算法·链表
大白话_NOI17 小时前
【洛谷 P2678】 [NOIP2015 提高组] 跳石头 超详细题解
c++·算法
xwz小王子18 小时前
ICRA 2026深度观察:全栈闭环成标配,中国具身智能势力显著崛起
大数据·人工智能·算法
孬甭_18 小时前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
DXM052118 小时前
第14期|高阶分割模型:Transformer/SegFormer遥感应用
人工智能·python·神经网络·算法·计算机视觉·cnn·ageo
Kurisu_红莉栖18 小时前
前缀和的另外一种用法,前缀和分解
算法
88号技师18 小时前
2026年2月一区SCI-交叉传播优化算法Propagation Alongside Crossover-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
悠仁さん18 小时前
数据结构 图(代码实现篇 C语言版)
数据结构·算法·图论
aini_lovee18 小时前
多智能体粒子群优化(Multi-Agent Particle Swarm Optimization, MAPSO)
算法