单链表反序实现
这个算法题有两种实现方式,一种是迭代,就是循环,还有一种是递归实现
迭代实现
迭代实现原理上是在一个循环如for中依次将一个节点的方向改变达到原地反序的实现
迭代法的核心是使用三个指针(prev
, curr
, next
)逐个节点调整指针方向,逐步将链表反转。具体步骤如下:
- 初始化指针:
prev
指向空,curr
指向头节点。 - 遍历链表:每次循环将
curr->next
指向prev
,然后更新prev
和curr
的指向。 - 终止条件:当
curr
遍历到链表尾部(curr == nullptr
)时停止。
struct ListNode {int val;ListNode* next;ListNode(int x) : val(x), next(nullptr) {}
};ListNode* reverseList(ListNode* head) {ListNode* prev = nullptr; // 前驱指针,初始为空ListNode* curr = head; // 当前指针,从头节点开始遍历while (curr != nullptr) {ListNode* next = curr->next; // 保存下一个节点curr->next = prev; // 反转当前节点的指针方向prev = curr; // prev指针前移,记录当前改的节点防止断链curr = next; // curr指针前移}return prev; // 最终prev指向新头节点(原链表尾节点)
}
以链表 1 → 2 → 3 → 4 → 5
为例,逐步演示反转过程:
步骤 | 操作前状态 | 操作后状态 | 关键代码 |
---|---|---|---|
1 | prev=null, curr=1 | 1→null, prev=1, curr=2 | curr->next = prev |
2 | prev=1, curr=2 | 2→1, prev=2, curr=3 | curr->next = prev |
3 | prev=2, curr=3 | 3→2, prev=3, curr=4 | curr->next = prev |
4 | prev=3, curr=4 | 4→3, prev=4, curr=5 | curr->next = prev |
5 | prev=4, curr=5 | 5→4, prev=5, curr=nullptr | curr->next = prev |
最终,prev
指向节点5(新头节点),链表变为 5 → 4 → 3 → 2 → 1
。
递归实现
递归的核心思想是将链表分解为头节点和剩余子链表两部分。递归反转子链表后,通过调整指针方向将头节点连接到反转后的子链表尾部,最终实现整个链表的反转
关键步骤:
- 终止条件:若链表为空(
head == nullptr
)或仅有一个节点(`head->next == nullptr``),直接返回头节点(无需反转)。 - 递归反转子链表:递归调用处理
head->next
后的子链表,返回反转后的新头节点rest
。 - 调整指针:将当前节点的下一个节点(
head->next
)的next
指向当前节点,形成反向连接,并将当前节点的next
置空以避免循环。
struct ListNode {int val;ListNode* next;ListNode(int x) : val(x), next(nullptr) {}
};ListNode* reverseList(ListNode* head) {// 终止条件:空链表或单节点链表无需反转if (head == nullptr || head->next == nullptr) {return head;}// 递归反转子链表,得到新头节点restListNode* rest = reverseList(head->next);// 调整指针方向head->next->next = head; // 子链表尾节点指向当前头节点head->next = nullptr; // 断开原链表的正向连接// 返回反转后的新头节点(即原链表的尾节点)return rest;
}
递归是有两个指针,一个head,一个rest记录新节点,递归分为递阶段和归阶段,在满足if条件的时候比如链表是12345,head会先一直走到5的位置,rest也会在5这个位置记录下来返回作为新的头节点 ,这时候head的next指针指向nullptr,不满足if条件,就不会再进行递了,再开始归执行下面的指针方向转换,每次执行完归一层,如5节点执行完会走到4。
注意:递归每次创建调用都会创建一套自己的新的变量,比如这个程序每次都是传入head的next作为参数构造,每次head都是一个全新的指针,他们的参数和作用域不同,和原来的head不同,他们只是名字相同。
相关文章:
单链表反序实现
这个算法题有两种实现方式,一种是迭代,就是循环,还有一种是递归实现 迭代实现 迭代实现原理上是在一个循环如for中依次将一个节点的方向改变达到原地反序的实现 迭代法的核心是使用三个指针(prev, curr, next)逐个…...

C++深入类与对象
在上一篇中提到了构造函数,那么这篇再来提一下构造函数,编译器自动生成的默认构造函数对于内置类型不做处理,自定义类型会调用它自己的构造函数。对于自己写的构造函数,之前是在函数体中初始化,当然不止这一种初始化&a…...
机器学习算法04:SVC 算法(向量机分类)
目录 一、算法核心特点 二、使用场景 三、代码示例(以 Python 的 scikit - learn 库为例) 四、与其他分类算法对比 SVC 即 Support Vector Classification,是支持向量机(SVM)在分类任务中的具体实现。在你正在阅读…...
Fragment事务commit与commitNow区别
在 Android 的 Fragment 事务处理中,commit() 和 commitNow() 是两种提交事务的方式,它们的区别主要体现在执行时机、事务顺序和兼容性等方面。以下是它们的核心区别: 1. 执行时机 commit() 将事务异步加入主线程的待执行队列。不会立即执行&…...
LVS-DR高可用-Keepalived
目录 Keepalved双机热备 核心概念 关键组件 工作流程 实例环境 配置keepalived Web服务器配置 Keepalved双机热备 Keepalived双机热备是一种基于VRRP(Virtual Router Redundancy Protocol,虚拟路由冗余协议)实现的高可用性解决方案&am…...

阿里云服务器邮件发送失败(dail tcp xxxx:25: i/o timeout)因为阿里云默认禁用 25 端口
最近在测试发送邮件的功能,发现了一个奇怪的问题,同样的 docker 镜像,在本地跑起来是可以正常发送邮件的,但是在阿里云的服务器上跑,就会报错 i/o timeout。 排查了一圈发现,原来是阿里云的操作࿰…...

力扣HOT100之动态规划:322. 零钱兑换
这道题和上一道题279.完全平方数的套路是完全一样的,但是这道题不需要我们自己生成物品列表,函数的输入中已经给出了,但是这道题有一个坑,就是我们在初始化dp数组的时候,所有的位置不应该赋值为INT_MAX,因为…...

电商售后服务系统与其他系统集成:实现售后流程自动化
在竞争激烈的电商市场中,优质的售后服务对于提升用户满意度和忠诚度至关重要。然而,售后服务流程通常涉及多个环节和系统,如何高效地管理这些流程,减少人工干预,提升服务效率,是电商企业亟待解决的问题。电…...

kafka学习笔记(三、消费者Consumer使用教程——消费性能多线程提升思考)
1.简介 KafkaConsumer是非线程安全的,它定义了一个acquire()方法来检测当前是否只有一个线程在操作,如不是则会抛出ConcurrentModifcationException异常。 acquire()可以看做是一个轻量级锁,它仅通过线程操作计数标记的方式来检测线程是否发…...
mongodb删除字段
删除普通字段 db.table.updateManay({}, {"$unset":{"要删除的字段": 1}})删除EmbeddedDocument字段 db.table.updateManay({}, {"$unset":{"models.name": 1}})models是个列表也可以这样删除字段 数据示例: { "m…...

[JVM] JVM内存调优
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…...
Liunx部署ES单机集群
ES 7.17.26 为例 一、单机 下载ES安装包 下载地址 wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.17.26-linux-x86_64.tar.gz wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.17.26-linux-x86_64.tar.gz.sha512…...

秒出PPT正式改名秒出AI,开启AI赋能新体验!
在现代办公环境中,借助智能工具提升工作效率已经成为趋势。秒出AI作为一款集AI PPT制作、动画、巨幕、视频、设计以及智能简历功能于一体的综合办公平台,为用户提供一站式智能内容生成解决方案,极大地简化了内容创作流程。 1. AI驱动的一键P…...
Unity中的AudioManager
1.先贴代码 using UnityEngine; using System.Collections.Generic; using System.Collections; using UnityEngine.SceneManagement;public class AudioManager : MonoSingleton<AudioManager> {[Header("Audio Settings")][SerializeField] private int ini…...

VM改MAC电脑密码(截图)
进入恢复模式重置密码 重启mac并同时按下CommandR,进入恢复模式。进入「菜单栏-实用程序-终端」,输入命令「resetpassword」回车运行,调出密码重置工具。选择包含密码的启动磁盘卷宗、需重设密码的用户账户;输入并确认新的用户密…...

SpringBoot+Vue+微信小程序校园自助打印系统
概述 校园自助打印系统是现代化校园建设中不可或缺的一部分,基于SpringBootVue微信小程序开发的免费Java源码项目,包含完整的用户预约、打印店管理等功能模块。 主要内容 系统功能模块 登录验证模块:…...

【论文精读】2024 CVPR--Upscale-A-Video现实世界视频超分辨率(RealWorld VSR)
文章目录 一、摘要二、挑战三、Method3.1 前置知识3.1.1 预训练SD 4 Upscaler3.1.2 Inflated 2D Convolution 扩展2D卷积 3.2 Local Consistency within Video Segments 视频片段中的一致性3.2.1 微调时序U-Net3.2.2 微调时序VAE-Decoder 3.3 跨片段的全局一致性 Global Consis…...

学术合作交流
想找志同道合的科研小伙伴!研究方向包括:计算机视觉(CV)、人工智能(AI)、目标检测、行人重识别、行人搜索、虹膜识别等。欢迎具备扎实基础的本科、硕士及博士生加入,共同致力于高质量 SCI 期刊和…...
【线上故障排查】Redis缓存与数据库中数据不一致问题的排查与同步策略优化
一、高频面试题 Redis缓存与数据库数据不一致的原因有哪些? 更新顺序问题:在读写并发场景下,若先更新缓存后更新数据库,此时其他读请求获取到的是旧的缓存数据;若先更新数据库后更新缓存,在更新缓存前其他读请求获取到的是旧数据,都可能导致数据不一致。缓存失效异常:缓…...
【Git命令】
基础命令 #初始化项目 git init #码云复制的路径,将本地仓库和码 云上的仓库关联起来 git remote add origin https://gitee.com/xx/xx.git#使用令牌 git remote set-url origin https://your-username:your-tokengithub.com/your-username/your-repository.gitgi…...

【LUT技术专题】图像自适应3DLUT
3DLUT开山之作: Learning Image-adaptive 3D Lookup Tables for High Performance Photo Enhancement in Real-time(2020 TPAMI ) 专题介绍一、研究背景二、图像自适应3DLUT方法2.1 前置知识2.2 整体流程2.3 损失函数的设计 三、实验结果四、局限五、总结…...
德拜温度热容推导
目录 一、背景与基本假设 一、态密度的定义 二、从波矢空间出发 三、振动模式数与波矢体积关系 四、模式总数计算 五、态密度求导 六、德拜频率确定与归一化条件 二、内能表达式的推导 三、态密度代入与变量替换 四、求比热容 五、低温时() …...
扫一扫的时候会经历哪些事
“扫一扫”功能(通常指扫描二维码或条形码)是一个看似简单但背后涉及多个步骤的过程。具体会做的事情取决于你使用的APP和扫描的码的类型(二维码最常见),但核心流程通常包括以下步骤: 启动摄像头并获取图像…...
Typescript学习教程,从入门到精通,TypeScript 泛型与类型操作详解(二)(17)
TypeScript 泛型与类型操作详解(二) 本文将详细介绍 TypeScript 中的一些高级类型特性,包括条件类型、分布式条件类型、infer 关键字、内置工具类型、类型查询、类型断言、类型细化和类型守卫等。 1. 条件类型(Conditional Type…...

【iOS】源码阅读(五)——类类的结构分析
文章目录 前言类的分析类的本质objc_class 、objc_object和NSObjectobjc_object:所有对象的基类型objc_class:类的底层结构NSObject:面向用户的根类 小结 指针内存偏移普通指针----值拷贝对象----指针拷贝或引用拷贝用数组指针引出----内存偏…...

基于CangjieMagic的RAG技术赋能智能问答系统
目录 引言 示例程序分析 代码结构剖析 导入模块解读 智能体配置详情 提示词模板说明 主程序功能解析 异步聊天功能实现 检索信息展示 技术要点总结 ollama 本地部署nomic-embed-text 运行测试 结语 引言 这段时间一直在学习CangjieMagic。前几天完成了在CangjieMa…...

算力租赁革命:弹性模式如何重构数字时代的创新门槛
一、算力革命:第四次工业革命的核心驱动力 在科技飞速发展的当下,我们正悄然迎来第四次工业革命。华为创始人任正非在一场程序设计竞赛中曾深刻指出,这场革命的基础便是大算力。随着 5G、人工智能、大数据、物联网等信息技术的迅猛发展&am…...

图论回溯
图论 200.岛屿数量DFS 给你一个由 ‘1’(陆地)和 ‘0’(水)组成的的二维网格,请你计算网格中岛屿的数量。岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。此外ÿ…...
使用arthas热替换在线运行的java class文件
如果我们在线的系统有问题,但又无法停机进行发版或者仅仅改了一个java文件需要验证一下功能是否正常,这时可以使用arthas的在线热替换功能来做class文件的在线变更。 1.运行java -jar arthas-boot.jar,启动arathas,并选择正在运行的java的进…...

RFID测温芯片助力新能源产业安全与能效提升
在“双碳”目标驱动下,新能源产业正经历爆发式增长。无论是电动汽车、储能电站还是风光发电场,设备安全与能效提升始终是行业核心命题。而温度,这个看似普通的物理参数,却成为破解这一命题的关键密码。RFID测温芯片(集…...