LeetCode 24 - 两两交换链表中的节点

题目描述

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

解题思路

交换链表中相邻节点的问题可以通过迭代或递归来解决。本文将介绍两种方法:

方法一:迭代法

  1. 使用一个虚拟头节点dummy,指向链表的实际头节点head,这样可以简化头节点的处理。
  2. 使用指针prev指向需要交换节点的前一个节点,初始化为dummy
  3. cur指向当前要交换的两个节点中的第一个节点,第二个节点由cur->next指向。
  4. 交换curcur->next中的两个节点,然后将指针前移,继续交换下一个一对节点直至链表末尾。

方法二:递归法

  1. 如果链表为空或者只有一个节点,直接返回头节点。
  2. 递归交换后续节点,并将当前节点与后续节点交换。

接下来是两种方法的具体实现。

算法实现

方法一:迭代法实现(C++实现)

cpp 复制代码
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode* dummyHead = new ListNode(0);
        dummyHead->next = head;
        ListNode* temp = dummyHead;
        while (temp->next != nullptr && temp->next->next != nullptr) {
            ListNode* node1 = temp->next;
            ListNode* node2 = temp->next->next;
            temp->next = node2;
            node1->next = node2->next;
            node2->next = node1;
            temp = node1;
        }
        ListNode* ans = dummyHead->next;
        delete dummyHead;
        return ans;
    }
};

方法二:递归法实现(C++实现)

cpp 复制代码
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        if (head == nullptr || head->next == nullptr) {
            return head;
        }
        ListNode* newHead = head->next;
        head->next = swapPairs(newHead->next);
        newHead->next = head;
        return newHead;
    }
};

复杂度分析

  • 方法一:迭代法

    • 时间复杂度:O(n),其中n是链表的长度。每两个节点进行一次交换,总体需要遍历整个链表。
    • 空间复杂度:O(1),只使用了有限的额外空间。
  • 方法二:递归法

    • 时间复杂度:O(n),每两个节点进行一次交换,总体需要遍历整个链表。
    • 空间复杂度:O(n),因为使用了递归调用,递归调用栈的深度取决于链表的长度。

总结

通过本文,我们介绍了两种解决LeetCode24题目中两两交换链表节点的方法:迭代法和递归法。两种方法都能有效地解决问题,但其不同点在于实现的风格和空间复杂度。迭代方法使用常数空间,适用于不希望使用递归的场景。而递归方法实现较为简洁,但占用较多栈空间。在实际应用中,可以根据具体需求选择合适的方法来解决这个问题。

希望这篇博客能对你有所帮助。如果有任何问题,欢迎随时讨论。

相关推荐
LYFlied5 小时前
【每日算法】LeetCode 105. 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·面试·职场和发展
DanyHope5 小时前
LeetCode 206. 反转链表:迭代 + 递归双解法全解析
算法·leetcode·链表·递归·迭代
NAGNIP5 小时前
才发现TensorBoard是个可视化的神器!
算法
MSTcheng.5 小时前
【C++】set / multiset 保姆级教程:从底层原理到实战应用!
开发语言·c++·set
历程里程碑5 小时前
C++ 16:C++11新特化
c语言·开发语言·数据结构·c++·经验分享
_dindong5 小时前
算法杂谈:回溯路线
数据结构·算法·动态规划·bfs·宽度优先
咋吃都不胖lyh5 小时前
详解 UCB 算法的置信区间与核心逻辑(通俗 + 公式 + 实例)
人工智能·算法·机器学习
DanyHope5 小时前
LeetCode 两数之和:从 O (n²) 到 O (n),空间换时间的经典实践
前端·javascript·算法·leetcode·职场和发展
xiaoye-duck5 小时前
吃透C++类和对象(中):拷贝构造函数的深度解析
c++
free-elcmacom5 小时前
机器学习高阶教程<6>推荐系统高阶修炼手册:混排、多任务与在线学习,解锁精准推荐新境界
人工智能·python·学习·算法·机器学习·机器人