news 2026/1/8 20:59:01

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/29 5:11:51

Open-AutoGLM电脑端部署实战指南(从安装到推理一键搞定)

第一章&#xff1a;Open-AutoGLM电脑端部署概述Open-AutoGLM 是一个基于 AutoGLM 架构的开源自动化语言模型工具&#xff0c;支持本地化部署与定制化推理任务。其电脑端部署方案旨在为开发者提供高性能、低延迟的模型运行环境&#xff0c;适用于科研实验、企业私有化部署及边缘…

作者头像 李华
网站建设 2025/12/24 13:18:14

Open-AutoGLM测试模型完全指南(从入门到精通的稀缺资料)

第一章&#xff1a;Open-AutoGLM测试模型完全指南&#xff08;从入门到精通的稀缺资料&#xff09;Open-AutoGLM 是一款面向自动化任务的开源大语言模型测试框架&#xff0c;专为开发者和研究人员设计&#xff0c;支持快速部署、模型评估与性能调优。通过该工具&#xff0c;用户…

作者头像 李华
网站建设 2026/1/5 2:07:12

2024年最稀缺的Open-AutoGLM替代方案曝光:仅1%开发者知道的黑科技

第一章&#xff1a;Open-AutoGLM类似的app哪个好用在探索自动化大语言模型&#xff08;LLM&#xff09;任务处理工具时&#xff0c;Open-AutoGLM 提供了灵活的本地化解决方案。然而&#xff0c;市场上也存在多个功能相似且用户体验更优的应用程序&#xff0c;能够满足不同场景下…

作者头像 李华
网站建设 2025/12/24 13:14:37

21、Elasticsearch聚合与分面查询深入解析(上)

Elasticsearch聚合与分面查询深入解析(上) 1. Geohash网格聚合 在进行数据聚合时,除了基于给定的点的距离进行聚合,还可以将区域组织成网格,把每个位置分配到合适的网格单元中。Geohash是实现这一目的的理想解决方案,它能将位置编码成字符串,字符串越长,对特定位置的…

作者头像 李华
网站建设 2025/12/27 16:59:22

声音数字主权宣言:个人对GPT-SoVITS模型的控制权

声音数字主权宣言&#xff1a;个人对GPT-SoVITS模型的控制权 在语音助手无处不在、AI主播频繁出镜的今天&#xff0c;你是否曾想过&#xff1a;谁真正拥有你的声音&#xff1f; 当我们在云端上传一段录音来“定制”自己的AI语音时&#xff0c;那份音频去了哪里&#xff1f;它会…

作者头像 李华