news 2026/2/2 5:07:36

hot 206

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
hot 206

【LeetCode 简单题】206. 反转链表:两种思路 + 代码详解

今天来拆解 LeetCode 上的经典简单题 ——206. 反转链表,这是链表操作的入门必刷题,同时也是很多面试的 “开胃菜”。本文会分享两种常用解法,从思路到代码逐一分析,帮你彻底搞懂链表反转的逻辑~

题目描述

给你单链表的头节点head,请你反转链表,并返回反转后的链表。

示例:输入:head = [1,2,3,4,5]输出:[5,4,3,2,1]

解法一:双指针法(原地反转,空间复杂度 O (1))

这是链表反转的最优解法,不需要额外空间,直接在原链表上修改指针指向。

思路分析

核心是用两个指针跟踪节点,通过 “断链 - 反转指向 - 移动指针” 的步骤,逐步将原链表的节点反向串联。

步骤拆解:

  1. 定义两个指针:newHead(指向反转后的新链表头,初始为nullptr)、temp(临时存储原链表的下一个节点);
  2. 遍历原链表,每次取出当前节点head
    • 先用temp保存head的下一个节点(防止断链后找不到后续节点);
    • headnext指向newHead(完成当前节点的反转);
    • 移动newHeadhead(新链表头更新为当前节点);
    • 移动headtemp(继续遍历原链表);
  3. 遍历结束后,newHead就是反转后的链表头。

代码实现

cpp

运行

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* reverseList(ListNode* head) { ListNode* newHead = nullptr; // 反转后的新链表头 ListNode* temp = nullptr; // 临时存储原链表的下一个节点 while (head) { temp = head->next; // 保存下一个节点 head->next = newHead; // 当前节点指向新链表头(反转) newHead = head; // 新链表头更新为当前节点 head = temp; // 继续遍历原链表 } return newHead; } };

解法二:辅助容器法(思路直观,空间复杂度 O (n))

如果对指针操作不熟悉,可以先用辅助容器暂存节点信息,再重新构建链表。这种方法思路更直观,适合新手理解。

思路分析

vector存储原链表的所有节点值,反转容器后,基于容器中的值创建新链表。

步骤拆解:

  1. 遍历原链表,将每个节点的val存入vector
  2. 反转vector(此时容器内的值是原链表的逆序);
  3. 创建一个虚拟头节点dummy(简化新链表的串联逻辑),遍历反转后的vector,依次创建新节点并串联;
  4. 返回虚拟头节点的next(即新链表的头)。

代码实现

class Solution { public: ListNode* reverseList(ListNode* head) { vector<int> vals; // 1. 存储原链表的所有节点值 while (head) { vals.emplace_back(head->val); head = head->next; } // 2. 反转容器(值的顺序逆序) reverse(vals.begin(), vals.end()); // 3. 基于反转后的值构建新链表 ListNode* dummy = new ListNode(0); // 虚拟头节点 ListNode* cur = dummy; for (int val : vals) { cur->next = new ListNode(val); // 创建新节点 cur = cur->next; // 移动指针 } return dummy->next; // 虚拟头的next是新链表头 } };

两种解法对比

解法时间复杂度空间复杂度适用场景
双指针法O(n)O(1)追求空间效率,面试推荐写法
辅助容器法O(n)O(n)新手理解链表反转逻辑,或需保留原链表

总结

反转链表是链表操作的基础题,双指针法是必须掌握的最优解(空间 O (1)、逻辑清晰),辅助容器法则是 “退而求其次” 的直观思路。建议先理解辅助容器法的逻辑,再过渡到双指针法的指针操作~

如果你有其他解法,欢迎在评论区交流~

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/26 0:17:31

GPT-SoVITS训练数据预处理技巧:提升音质的关键步骤

GPT-SoVITS训练数据预处理技巧&#xff1a;提升音质的关键步骤 在语音合成领域&#xff0c;一个清晰、自然、富有表现力的“声音”往往决定了用户体验的上限。而今天&#xff0c;哪怕你只有一分钟的录音&#xff0c;也能通过像 GPT-SoVITS 这样的先进模型&#xff0c;克隆出高度…

作者头像 李华
网站建设 2026/2/2 3:42:26

学长亲荐10个AI论文工具,专科生轻松搞定毕业论文!

学长亲荐10个AI论文工具&#xff0c;专科生轻松搞定毕业论文&#xff01; AI 工具助力论文写作&#xff0c;专科生也能轻松应对 对于很多专科生来说&#xff0c;毕业论文仿佛是一道难以逾越的门槛。从选题、查找资料到撰写、修改&#xff0c;每一步都充满挑战。而如今&#xff…

作者头像 李华
网站建设 2026/2/1 2:43:42

Open-AutoGLM核心机制揭秘:5个指标决定你的模型是否达标

第一章&#xff1a;Open-AutoGLM核心机制揭秘&#xff1a;5个指标决定你的模型是否达标Open-AutoGLM 作为新一代开源自动语言生成框架&#xff0c;其性能评估不再依赖单一准确率指标&#xff0c;而是通过五个关键维度综合判定模型是否达到生产级标准。这些指标共同构成模型能力…

作者头像 李华
网站建设 2026/1/27 15:52:01

风电场参与下的市场竞价策略:探索电力市场新玩法

风电场参与下的市场竞价策略 在当今能源转型的大浪潮下&#xff0c;风电场作为清洁能源的重要力量&#xff0c;正逐渐在电力市场中崭露头角。然而&#xff0c;风电场由于其发电的间歇性和不确定性&#xff0c;在参与市场竞价时面临着独特的挑战和机遇。今天咱们就来深入探讨下风…

作者头像 李华
网站建设 2026/2/2 0:19:18

【Open-AutoGLM电脑版深度解析】:解锁本地大模型部署的5大核心优势

第一章&#xff1a;Open-AutoGLM电脑版深度解析Open-AutoGLM 是一款面向本地化大模型推理与自动化任务执行的开源工具&#xff0c;专为在个人计算机上高效运行 GLM 系列语言模型而设计。其核心优势在于将自然语言理解能力与系统级操作相结合&#xff0c;实现从文本输入到实际功…

作者头像 李华