当前位置: 首页 > news >正文

LeetCode算法题 (反转链表)Day17!!!C/C++

https://leetcode.cn/problems/reverse-linked-list/description/

一、题目分析

        给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。今天这道题目非常的言简意赅,就是给定一个链表将其反转后返回反转后的头节点。

二、示例分析

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

 三、解题思路&代码实现

        方法一:双指针法

               我们可以定义一个前驱节点 pre 和一个当前节点 cur,初始时 pre = nullptrcur 指向头节点。每次遍历时,我们暂存 cur 的下一个节点,然后将 cur->next 指向 pre,完成当前节点的反转。接着,pre 和 cur 分别向后移动,直到 cur 为 nullptr。此时 pre 指向反转后的新头节点,整个链表完成逆序。

class Solution {
public:ListNode* reverseList(ListNode* head) {// 如果链表为空,直接返回nullptrif (head == nullptr)return nullptr;// pre指针用于记录当前节点的前一个节点,初始为nullptrListNode* pre = nullptr;// cur指针用于遍历链表,初始指向头节点ListNode* cur = head;// 遍历链表,直到cur为nullptr(即链表末尾)while (cur) {// 临时保存当前节点的下一个节点,防止断链后丢失ListNode* t = cur->next;// 将当前节点的next指针指向前一个节点,实现反转cur->next = pre;// 移动pre指针到当前节点,为下一次迭代做准备pre = cur;// 移动cur指针到之前保存的下一个节点,继续遍历cur = t;}// 循环结束后,pre指向原链表的最后一个节点,即反转后的新头节点return pre;}
};

图文说明:

        

        方法二:递归法

                递归法和双指针法大致思想一致,具体实现代码稍稍有些差异,需要着重搞清楚每次递归时需要传的参数分别是什么。

class Solution {
public:// 递归反转链表的辅助函数// pre: 已经反转部分的头节点(初始为nullptr)// cur: 当前待反转的节点(初始为原链表头节点)ListNode* reverse(ListNode* pre, ListNode* cur) {// 递归终止条件:当前节点为空,说明已处理完所有节点// 此时pre就是反转后的新头节点if (cur == nullptr)return pre;// 保存当前节点的下一个节点,防止断链ListNode* t = cur->next;// 反转当前节点的指向cur->next = pre;// 递归处理下一个节点:// 新的pre变为当前节点(已反转部分的头节点)// 新的cur变为之前保存的下一个节点return reverse(cur, t);}// 主函数:反转整个链表ListNode* reverseList(ListNode* head) { // 调用辅助函数// 这里等同于// ListNode* pre = nullptr;// ListNode* cur = head;return reverse(nullptr, head); }
};

关键点说明:

  1. 递归思想:将链表分为“已反转部分“与”未反转部分“,每次处理一个节点。
  2. 终止条件:当cur为空时,说明所有节点已经反转完毕。
  3. 指针操作:每次递归调用前保存cur->next节点,防止找不到后继节点。将当前节点指向前驱节点。
  4. 参数传递:pre始终指向已反转部分的头节点,cur始终指向待处理的下一个节点

时间复杂度上与方法一相同,但空间复杂度为O(n)。个人感觉递归其实还是挺难理解的,但是当你搞清楚递归之后,在代码量上,会比普通写法要简介很多。

方法三:头插法(不提供代码,请同学自行实现)

        这里主要讲述一下思想,感兴趣的小伙伴可以自己动手试一试。

        核心思想:遍历原链表,逐一拿下每一个节点,插入到一个新链表的头部,最后新链表就是逆序后的链表。

        关键步骤:

  1. 初始化一个虚拟头节点dummy),作为新链表的辅助节点。

  2. 遍历原链表,每次操作:

    • 保存当前节点的下一个节点(next = cur->next)。

    • 将当前节点插入到新链表头部(cur->next = dummy->next)。

    • 更新新链表的头(dummy->next = cur)。

    • 移动当前节点到原链表的下一个节点(cur = next)。

  3. 返回 dummy->next,即逆序后的新链表头节点。

在上述两种方法如果大家掌握了的话,这种方法实现起来应该是没有问题的。虽然不推荐,但是相比方法一、二也是有好处,比如直观更容易理解,无需递归不需要考虑栈溢出。但这种方法主要还是锻炼大家的算法思维。

四、题目总结

  • 双指针法:定义前驱指针 pre 初始为 nullptr,当前指针 cur 指向头节点。遍历链表,每次暂存 cur 的下一个节点 t,然后将 cur->next 指向 pre 实现当前节点反转,再移动 pre 和 cur 指针,直至 cur 为 nullptr,此时 pre 为反转后新头节点。时间复杂度 O (n),空间复杂度 O (1) 。
  • 递归法:将链表分为 “已反转部分” 和 “未反转部分”,通过递归处理节点。辅助函数 reverse 接收已反转部分头节点 pre(初始 nullptr)和当前待反转节点 cur(初始为头节点),保存 cur->next 防止断链,将 cur->next 指向 pre,再递归调用 reverse(cur, t) 处理下一个节点,终止条件为 cur 为空,此时 pre 是新头节点。时间复杂度 O (n) ,空间复杂度 O (n) 。
  • 头插法:遍历原链表,把每个节点逐一插入新链表头部,新链表即为反转后的链表。思想直观,利于锻炼算法思维,无需递归避免栈溢出问题。

对于每道题目,解法往往具有多样性。我们首先应掌握一种直观且基础的解法,这种解法可能较为“暴力”,但能帮助我们初步解决问题。在此基础上,再对代码进行优化,逐步探寻相对最优的解法。今天的分享就到这里,谢谢大家!!!荆轲刺秦!!!

相关文章:

LeetCode算法题 (反转链表)Day17!!!C/C++

https://leetcode.cn/problems/reverse-linked-list/description/ 一、题目分析 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。今天这道题目非常的言简意赅,就是给定一个链表将其反转后返回反转后的头节点。 二、示例分析 输…...

3.5/Q1,GBD数据库最新一区文章解读

文章题目:Global burden of low vision and blindness due to age-related macular degeneration from 1990 to 2021 and projections for 2050 DOI:10.1186/s12889-024-21047-x 中文标题:1990年至2021年因年龄相关性黄斑变性导致的低视力和失…...

【AI论文】像素修补师(PixelHacker):具有结构和语义一致性的图像修复(Image Inpainting)

摘要:图像修复是图像编辑和图像生成之间的一个基础研究领域。 最近最先进的方法(SOTA)探索了新的注意力机制、轻量级架构和上下文感知建模,展示了令人印象深刻的性能。 然而,他们经常在复杂的结构(如纹理、…...

卡洛诗中式西餐,打破“高价即高端”认知

在餐饮消费从“功能满足”向“意义消费”跃迁的今天,Z世代对饮食的期待早已超越“吃饱”的生理需求。萨莉亚原团队成员出来升级孵化的新概念西餐卡洛诗作为中式西餐赛道的破局者,通过场景重构、产品升维与情感绑定,将西餐体验转化为情绪的载体…...

Sui 上线两周年,掀起增长「海啸」

两年前的 5 月 3 日,Sui 的主网正式发布,将在开发网和测试网上验证过的下一代技术承诺变为现实。这一新兴网络旨在优化现有区块链技术,结合高性能计算环境与安全性、可验证性及韧性。 随着 Sui 迎来两周年,这股浪潮已成长为「海啸…...

手写 Vue 源码 === reactive 方法

目录 1. 响应式系统概述 2. Proxy与Reflect的应用 3. 响应式对象的创建 4. WeakMap的使用 主要特点 WeakMap 与 Map 的区别 应用场景 5. 依赖收集与触发更新 6. 响应式标记 7. 性能优化 8. 与Vue2的对比 9. 实际应用示例 10. 总结 Vue3的响应式系统是其核心特性…...

第一章-Rust入门

Rust 简介 Rust 是一种强类型的静态编程语言,它可以编写更快、更可靠的软件,兼备高层次的易用性与低层次的控制力。 Rust 具有以下几个特点: 内存安全,且不牺牲性能“编译通过就能正常运行”令人愉悦的语法和强大的语言特性优秀…...

【AI入门】Cherry入门1:Cherry Studio的安装及配置

前言 尝试了Trae配置MCP,测试了n8n设置MCP工作流,但感觉好累啊,CherryStudio横空出世,开着中文界面,就倍感亲切,看着大家操作很丝滑的样子,咱也鸟枪换炮了,哇哈哈😄&…...

雷电模拟器-超好用的Windows安卓模拟器

一、雷电模拟器介绍 雷电模拟器是一款功能强大的软件,它能够在电脑上模拟出安卓手机系统,让你可以在电脑上运行各类手机应用及游戏。其采用虚拟安卓手机操作界面,为玩家带来了独特的体验。 (一)强大的兼容性 雷电模拟…...

数据集-目标检测系列- 蜥蜴 检测数据集 lizard >> DataBall

数据集-目标检测系列- 蜥蜴 检测数据集 lizard >> DataBall DataBall 助力快速掌握数据集的信息和使用方式。 贵在坚持! * 相关项目 1)数据集可视化项目:gitcode: https://gitcode.com/DataBall/DataBall-detections-100s/overview…...

Kubernetes控制平面组件:Controller Manager 之 NamespaceController 全方位讲解

云原生学习路线导航页(持续更新中) kubernetes学习系列快捷链接 Kubernetes架构原则和对象设计(一)Kubernetes架构原则和对象设计(二)Kubernetes架构原则和对象设计(三)Kubernetes控…...

数据结构小扫尾——栈

数据结构小扫尾——栈 jarringslee 文章目录 数据结构小扫尾——栈栈本质上是一种特殊的线性表。(一)线性表的定义(二)线性表的运算 什么是栈。(一)栈的定义(二)栈的分类&#xff0…...

策略模式(Strategy Pattern)

🧠 策略模式(Strategy Pattern) 策略模式是一种行为型设计模式,它允许定义一系列的算法或行为,然后将每个算法封装到一个类中,使得它们可以互换。策略模式让算法独立于使用它的客户端进行变化,…...

Qwen2_5-Omni-3B:支持视频、音频、图像和文本的全能AI,可在本地运行

Qwen2.5-Omni-3B是阿里云推出的全能AI模型。它能同时处理视频、音频、图像和文本。只有3B参数,却能在本地运行强大的多模态功能。 近日,已经在Hugging Face上发布。它是小型多模态AI系统的重要突破。 特点 Qwen2.5-Omni-3B与普通语言模型不同。它是真正的多模态系统,可以同…...

GZIPOutputStream 类详解

GZIPOutputStream 类详解 GZIPOutputStream 是 Java 中用于压缩数据为 GZIP 格式的输出流类,属于 java.util.zip 包。它是 DeflaterOutputStream 的子类,专门生成符合 GZIP 格式(.gz 文件)的压缩数据。 1. 核心功能 将数据压缩为…...

sudo useradd -r -s /bin/false -U -m -d /usr/share/ollama ollama解释这行代码的含义

这行命令用于为 OLLAMA 服务创建专用的系统用户,具体参数解析如下: sudo 以管理员权限执行命令,确保有足够权限创建系统用户。 useradd Linux 用户创建命令,用于在系统中新增用户。 -r 创建系统账户(非登录用户&…...

自注意力(Self-Attention)和位置编码

自注意力 给定序列 x 1 , … , x n \mathbf{x}_1, \ldots, \mathbf{x}_n x1​,…,xn​, ∀ x i ∈ R d \forall \mathbf{x}_i \in \mathbb{R}^d ∀xi​∈Rd 自注意力池化层将 x i \mathbf{x}_i xi​ 当做key, value, query来对序列抽取特征得到 y 1 , … , y n \mathbf{y}…...

Linux压缩和解压类

一、gzip/gunzip 压缩 1、基本语法 gzip 文件 (功能描述:压缩文件,只能将文件压缩为*.gz文件) gunzip 文件.gz (功能描述:解压缩文件命令) 2、经验技巧 (1&#…...

Kubernetes控制平面组件:Controller Manager详解

云原生学习路线导航页(持续更新中) kubernetes学习系列快捷链接 Kubernetes架构原则和对象设计(一)Kubernetes架构原则和对象设计(二)Kubernetes架构原则和对象设计(三)Kubernetes控…...

使用 JavaScript 实现数据导出为 Excel 和 CSV 文件

在 Web 开发中,经常会遇到需要将数据导出为文件的需求,例如将数据导出为 Excel 或 CSV 文件。今天,我们就来探讨如何使用 JavaScript 实现这一功能。 一、实现思路 我们通过 HTML 创建一个按钮,点击按钮时,触发 Java…...

设一个测试情境,新用户注册后显示的名字不完整,测试思路是怎么样的?

问题分析:新用户注册后显示名称不完整 典型表现:用户注册时输入"张三丰",系统仅显示"张"或"张三"等不完整信息 一、测试排查思维导图 二、详细测试方案 1. 前端测试 输入验证: 测试不同长度名称(1字符/10字符/50字符) 测试含空格名称(如…...

NHANES指标推荐:ZJU index

文章题目:Association between ZJU index and gallstones in US adult: a cross-sectional study of NHANES 2017-2020 DOI:10.1186/s12876-024-03553-9 中文标题:ZJU指数与美国成年人胆结石的关联:2017-2020年NHANES横断面研究 发…...

数据存储——高级存储之PV和PVC

一、概述 PV ( Persistent Volume )是持久化卷的意思,是对底层的共享存储的一种抽象。一般情况下 PV 由 kubernetes 管理员进行创建和配置,它与底层具体的共享存储技术有关,并通过插件完成与共享存储的对接。 PVC &a…...

Astro Canvas 数据中心→设备一览大屏操作指南

✅ Astro Canvas 数据中心→设备一览大屏操作指南 📌 目标 通过API连接器 → 转换器 → 数据源 → 数据集 → Astro大屏设计,展示从 IoTDA 获取的设备影子数据,并在 Astro 大屏中以设备一览形式可视化展示(如设备ID、温度、湿度、烟雾浓度等状态)。 🔁 一、整体流程概…...

Cisco NDO - Nexus Dashboard Orchestrator

目录 一、什么是 Cisco NDO? 二、ND vs. NDO? 三、NDO vs. NDFC 四、NDO 用例: 一、什么是 Cisco NDO? Nexus Dashboard Orchestrator(NDO)可通过单一界面,实现跨多个数据中心的一致性网络与策略编排、可扩展性与灾难恢复等。 当在本地、多种私有云或公有云中同时运…...

Android 控件CalendarView、TextClock用法

一 UI代码 <?xml version="1.0" encoding="utf-8"?> <androidx.coordinatorlayout.widget.CoordinatorLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto…...

Socket 编程 TCP

Socket 编程 TCP TCP socket API 详解V1 - Echo ServerV2 - Echo Server 多进程版本V3 - Echo Server 多线程版本V4 - Echo Server 线程池版本多线程远程命令执行v5 引入线程池版本翻译 TCP socket API 详解 socket(): socket()打开一个网络通讯端口,如果成功的话,就像 open…...

信息系统项目管理师-软考高级(软考高项)​​​​​​​​​​​2025最新(七)

个人笔记整理---仅供参考 项目立项管理 7.1项目建议与立项申请 项目建议书内容必背&#xff01; 7.2项目可行性研究 项目可行性研究必考 7.3项目的评估与决策...

Qt中的UIC

Qt中的UIC(User Interface Compiler, 用户界面编译器)&#xff1a;读取由Qt Widgets Designer生成的XML格式(.ui)文件并创建相应的C头文件或Python源文件。如将mainwindow.ui文件生成ui_mainwindow.h。 uic.exe位置在6.8.0\msvc2019_64\bin &#xff0c;其支持的输入参数如下所…...

【MATLAB例程】基于RSSI原理的Wi-Fi定位程序,N个锚点(数量可自适应)、三维空间,轨迹使用UKF进行滤波,附代码下载链接

本文所述程序实现了一种基于信号强度&#xff08;RSSI&#xff09;的Wi-Fi定位算法&#xff0c;并结合无迹卡尔曼滤波&#xff08;UKF&#xff09;对动态目标轨迹进行滤波优化。代码支持自适应锚点数量&#xff0c;适用于三维空间定位&#xff0c;可模拟目标运动、信号噪声及非…...

vulkanscenegraph显示倾斜模型(6.5)-vsg::DatabasePager

前言 上章深入分析了帧循环过程中&#xff0c;多线程下的记录与提交机制。本章将分析vsg::DatabasePager在更新场景图过程中的作用&#xff0c;进一步揭露vsg中场景图管理机制&#xff0c;并通过分析代码&#xff0c;详细解释vsg中场景图管理机制中的节点添加、节点删除、节点加…...

利用 Python pyttsx3实现文字转语音(TTS)

今天&#xff0c;我想跟大家分享如何利用 Python 编程语言&#xff0c;来实现文字转换为语音的功能&#xff0c;也就是我们常说的 Text-to-Speech (TTS) 技术。 你可能会好奇&#xff0c;为什么学习这个&#xff1f;想象一下&#xff0c;如果你想把书本、文章、杂志的内容转换…...

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】5.1 描述性统计分析(均值/方差/分位数计算)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 5.1 描述性统计分析&#xff1a;均值、方差与分位数计算实战5.1.1 数据准备与分析目标数据集介绍分析目标 5.1.2 均值计算&#xff1a;从整体到分组分析总体均值计算加权均值…...

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】5.4 数据抽样(简单随机抽样/分层抽样)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 PostgreSQL数据分析实战&#xff1a;数据抽样核心技术解析5.4 数据抽样&#xff1a;从简单随机到分层策略的深度实践5.4.1 简单随机抽样&#xff1a;概率均等的基础抽样方法…...

时间同步服务核心知识笔记:原理、配置

一、时间同步服务 在 Linux 系统中&#xff0c;准确的时间至关重要。对于服务器集群&#xff0c;时间同步确保各节点间数据处理和交互的一致性&#xff0c;避免因时间差异导致的事务处理错误、日志记录混乱等问题。在分布式系统中&#xff0c;时间同步有助于协调任务调度、数据…...

Leetcode刷题记录32——搜索二维矩阵 II

题源&#xff1a;https://leetcode.cn/problems/search-a-2d-matrix-ii/description/?envTypestudy-plan-v2&envIdtop-100-liked 题目描述&#xff1a; 思路一&#xff1a; &#x1f4a1; 解题思路&#xff1a;利用矩阵有序特性 双指针法&#xff08;Z 字形搜索&…...

【最新Python包管理工具UV的介绍和安装】

介绍 uv是一个非常快的 Python 包安装程序和 pip 解析器&#xff0c;用 Rust 编写&#xff0c;设计为pip-tools的直接替代品。 以下是官网给出的UV与其他包管理工具解决依赖&#xff08;左&#xff09;和安装包&#xff08;右&#xff09;的对比图。 可以看出UV是一个极快的 P…...

第二章-猜数游戏

猜数游戏 纸上得来终觉浅&#xff0c;绝知此事要躬行。实践才能出真知&#xff0c;因此本文内容将通过一个小项目快速帮我们上手Rust语言。其中可能会出现一些目前还不是很了解的知识&#xff0c;但没事&#xff0c;后续通过学习我们会慢慢了解的&#xff0c;现在我们先体会一…...

Go小技巧易错点100例(二十九)

随着 Go 语言的不断迭代&#xff0c;新版本带来了许多实用的标准库函数&#xff0c;使得代码更加简洁、可读性更强。本篇文章主要介绍 Go 1.21 版本中的一些新特性&#xff0c;涵盖 可变类型比较、slice 最大值与最小值、map 转换为 slice 以及 map 合并 等常见场景&#xff0c…...

游戏开发的TypeScript(5)TypeScript的类型转换

TypeScript的类型转换 游戏开发中&#xff0c;事件经常会携带一些数据&#xff0c;而这些数据会做类型上的转化&#xff0c;在 这种情况下&#xff0c;类型转换&#xff08;Type Assertion&#xff09;能够让你手动把某个值指定为特定类型。这在 TypeScript 无法自动推断出正确…...

旋转图像(中等)

借助辅助矩阵来翻转&#xff1a; 第i行第j列的元素会出现在新矩阵的第j行倒数第i列。 class Solution {public void rotate(int[][] matrix) {int n matrix.length;int[][] matrix_new new int[n][n];for (int i 0; i < n; i) {for (int j 0; j < n; j) {matrix_ne…...

慢sql处理流程和常见案例

思维导图: 在 MySQL 数据库管理中&#xff0c;慢查询是影响系统性能的常见痛点。随着 MySQL 8 版本的普及&#xff0c;其新增特性&#xff08;如 CTE、隐藏索引、JSON 格式执行计划等&#xff09;为慢查询优化提供了更强大的工具。本文结合 MySQL 8 的特性&#xff0c;通过代码…...

Kubernetes控制平面组件:Controller Manager 之 内置Controller详解

云原生学习路线导航页&#xff08;持续更新中&#xff09; kubernetes学习系列快捷链接 Kubernetes架构原则和对象设计&#xff08;一&#xff09;Kubernetes架构原则和对象设计&#xff08;二&#xff09;Kubernetes架构原则和对象设计&#xff08;三&#xff09;Kubernetes控…...

E-R图作业

1.一个图书馆借阅管理数据库要求提供下述服务&#xff1a; &#xff08;&#xff11;&#xff09;可随时查询书库中现有书籍的品种、数量与存放位置。所有各类书籍均可由书号惟一标识。 &#xff08;&#xff12;&#xff09;可随时查询书籍借还情况&#xff0c;包括借书人单位…...

debuginfo详解

debuginfo 是 Linux 系统中存储调试符号和源代码信息的特殊软件包&#xff0c;用于分析内核或用户态程序的崩溃转储文件&#xff08;如 vmcore、coredump&#xff09;。它在调试复杂问题&#xff08;如内核崩溃、程序段错误&#xff09;时至关重要。以下是其核心作用、安装方法…...

Android学习总结之GetX库篇(场景运用)

状态管理 在一个复杂的 Flutter 应用里&#xff0c;怎样借助 GetX 管理多个相互关联的状态&#xff0c;并且保证代码的可维护性和性能&#xff1f; 考察点&#xff1a;对 GetX 状态管理的深入理解&#xff0c;以及在复杂场景下运用它的能力。 解答思路&#xff1a; 采用模块…...

android-ndk开发(5): 编译运行 hello-world

android-ndk开发(5): 编译运行 hello-world 2025/05/05 1. 概要 hello-world 是每一门语言的第一个样例程序&#xff0c; 跑通它&#xff0c; 在一段时间内你会相当顺畅&#xff1a; 可以边学边实验&#xff0c; 根据运行结果得到反馈。 而对于 android-ndk 开发而言&#…...

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】6.1 客户分群分析(RFM模型构建)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 PostgreSQL数据分析实战&#xff1a;RFM模型构建实现客户分群分析6.1 客户分群分析——RFM模型构建6.1.1 RFM模型核心指标解析6.1.2 数据准备与清洗规范数据表结构设计数据清…...

stm32之TIM定时中断详解

目录 1.引入1.1 简介1.2 类型1.2.1 基本定时器1.2.2 通用定时器1. 触发控制单元 (Trigger Control Unit)2. 输入捕获单元 (Input Capture Unit)3. 输出比较单元 (Output Compare Unit)4. CNT 计数器5. 自动重装载寄存器 (ARR)6. 预分频器 (PSC)7. 中断与 DMA 事件8. 刹车功能 (…...

【Hive入门】Hive安全管理与权限控制:用户认证与权限管理深度解析

目录 引言 1 Hive安全管理体系概述 2 Hive用户认证机制 2.1 Kerberos集成认证 2.1.1 Kerberos基本原理 2.1.2 Hive集成Kerberos配置步骤 2.1.3 Kerberos认证常见问题排查 2.2 LDAP用户同步 2.2.1 LDAP协议概述 2.2.2 Hive集成LDAP配置 2.2.3 LDAP与Hive用户同步架构…...