反转链表:三种实现思路与细节梳理

反转链表是链表操作中最基础、最经典的问题之一。看似简单,却能很好地体现对指针、递归、边界处理的理解程度。本文从三种不同思路实现反转链表,并对每一种写法的逻辑与细节做完整梳理。

问题描述

206. 反转链表:给你单链表的头节点 head,请将该链表反转,并返回反转后的链表头节点。

方法一:头插法

头插法的思路非常直观:构建一个新链表,依次将原链表的节点插入到新链表头部,最终得到的链表自然是原链表的逆序。

代码

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

        ListNode* dummy = new ListNode(0, head);
        ListNode* cur = head->next;
        ListNode* next = cur->next;

        head->next = nullptr;

        while (cur != nullptr) {
            cur->next = dummy->next;
            dummy->next = cur;
            cur = next;
            if (next) next = next->next;
        }

        ListNode* res = dummy->next;
        delete dummy;
        return res;
    }
};

特点

  • 思路清晰,容易理解与实现
  • 借助虚拟头节点,统一处理逻辑
  • 时间复杂度 O (n),空间复杂度 O (1)

方法二:三指针迭代法

使用三个指针依次向后遍历,逐个修改节点指向,原地完成反转。这是最常用、最稳健的迭代写法,逻辑紧凑、效率稳定。

代码

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

        ListNode* prev = head;
        ListNode* cur = head->next;
        ListNode* next = cur->next;

        prev->next = nullptr;

        while (cur != nullptr) {
            cur->next = prev;
            prev = cur;
            cur = next;
            if (next) next = next->next;
        }

        return prev;
    }
};

特点

  • 迭代实现,无栈溢出风险
  • 时间复杂度 O (n),空间复杂度 O (1)
  • 工程中最推荐的写法

方法三:递归实现

递归思路将问题分解为:**先反转后续子链表,再处理当前节点的指向关系。**代码简洁,适合理解递归思想与链表结构。

  • 先递归到链表的最后一个节点,使得newhead记录下反转后的头结点,即原链表的尾结点
  • 然后在 "回溯" 的过程中,逐个修改节点的指向,让每个节点的next指向自己的前一个节点。

代码

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

        ListNode* newHead = reverseList(head->next);

        head->next->next = head; // 使下一节点指向自己
        head->next = nullptr; // 使自己指向NULL

        return newHead;
    }
};

特点

  • 代码简洁
  • 依靠递归栈实现,空间复杂度 O (n)
  • 适合理解分治思想与链表回溯过程

总结

反转链表虽然基础,但包含了链表操作的核心要点:

  • 边界判断:空链表、单节点链表直接返回
  • 指针移动顺序:避免断链与空指针访问
  • 尾节点必须置空,防止出现环
  • 迭代与递归各有适用场景,可根据需求选择

扎实掌握这几种写法,能为更复杂的链表题目打下坚实基础。

相关推荐
j_xxx404_18 分钟前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
我能坚持多久18 分钟前
【初阶数据结构07】——栈与队列的代码实现与解析
数据结构
We་ct43 分钟前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
Aaswk2 小时前
蓝桥杯2025年第十六届省赛真题(更新中)
c语言·数据结构·c++·算法·职场和发展·蓝桥杯
Yvonne爱编码2 小时前
JAVA数据结构 DAY7-二叉树
java·开发语言·数据结构
总斯霖2 小时前
P15445永远在一起!题解(月赛T2)
数据结构·c++·算法·深度优先
像污秽一样3 小时前
算法设计与分析-习题4.5
数据结构·算法·排序算法·剪枝
样例过了就是过了3 小时前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs
xh didida3 小时前
数据结构--实现链式结构二叉树
c语言·数据结构·算法
ab1515173 小时前
3.15二刷基础90、105、106、110
数据结构·c++·算法