【Leetcode 206】 反转链表——此递归相当妙啊

题目 

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

示例 1:

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

示例 2:

输入:head = [1,2]
输出:[2,1]

示例 3:

输入:head = []
输出:[]

提示:

  • 链表中节点的数目范围是 [0, 5000]
  • -5000 <= Node.val <= 5000

题解

/** 迭代 通过将每一个节点的next的指向改为指向前一个节点,则相当于逆置*/
function reverseList2(head: ListNode | null): ListNode | null {// 创建pre指针,指向当前节点的前一个节点,let pre = null;//当前节点的指针let cur = head;while (cur) {//保存下一个节点,因为当修改了next指向前一个节点时,就无法找到下一个节点了let nex = cur.next;//将节点的next的指向改为指向前一个节点cur.next = pre;//向后移动两个指针pre = cur;cur = nex;}//   cur这时候为null,pre为最后一个节点,也就是逆置后的头节点return pre;
}/** 递归 */
function reverseList(head: ListNode | null): ListNode | null {//如果head 为空(只在链表为空时,!head 条件才会成立)// !head.next 为空,则head为尾节点,则返回headif (!head || !head.next) return head;//递归链表,直到最后,并保存每一个节点const newHead = reverseList(head.next);//head 节点为当前节点,将下一个节点的next指针指回上一个节点// 如 原本是  4 -> 5 -> 6  ,head为5 ,5.next = 6// 此操作后为 4 -> 5 -> <- 6 , 将 6.next = 5head.next.next = head;//由于上步操作后,5 和 6 相互指向,会成死循环,// 此操作后  4 -> 5 <- 6head.next = null;// 由于递归为栈操作,所以最后返回的newHead为反转链表的表头return newHead;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/19429.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机器学习300问】105、计算机视觉(CV)领域有哪些子任务?

计算机视觉作为人工智能的重要分支&#xff0c;发展至今已经在诸多领域取得显著的成果。在众多的计算机视觉任务中&#xff0c;图像分类、目标检测与定位、语义分割和实例分割是四个基本而关键的子任务&#xff0c;它们在不同的应用场景下扮演着重要角色。这四个子任务虽然各具…

深入理解JVM:内存结构、垃圾收集与性能调优

目录 JDK、JRE、JVM关系? 启动程序如何查看加载了哪些类&#xff0c;以及加载顺序? class字节码文件10个主要组成部分? JVM结构 画一下JVM内存结构图 程序计数器 Java虚拟机栈 本地方法栈 Java堆 方法区 运行时常量池? 什么时候抛出StackOverflowError? 例如&…

海医大三院使用先进血管外科微创技术成功救治危重主动脉夹层患者

近日,上海东方肝胆外科医院血管外科周建教授团队采用主动脉弓分支型一体化移植物联合体外开窗技术,成功救治复杂危重主动脉夹层患者,为上海嘉定首例,彰显了上海东方肝胆外科医院血管外科的优势与特色。 患者谢先生,72岁,两周前突发剧烈胸背部撕裂样疼痛,休息后症状未能得到缓解…

多模态开源项目实战(https://github.com/QwenLM/Qwen-VL)

GitHub - HqWu-HITCS/Awesome-Chinese-LLM: 整理开源的中文大语言模型&#xff0c;以规模较小、可私有化部署、训练成本较低的模型为主&#xff0c;包括底座模型&#xff0c;垂直领域微调及应用&#xff0c;数据集与教程等。 1.AttributeError: ChatGLMTokenizer object has n…

量化交易:如何在QMT中运行Python策略并在VSCode中高效调试?

哈喽&#xff0c;大家好&#xff0c;我是木头左&#xff01; 为何选择QMT和VSCode进行量化策略开发&#xff1f; 在量化交易的世界里&#xff0c;选择正确的工具与拥有优秀的策略同等重要。调用用Visual Studio Code&#xff08;简称VSCode&#xff09;或pycharm&#xff0c;方…

JAVA 大鱼吃小鱼小游戏

java实现大鱼吃小鱼&#xff0c;支持身份证防沉迷、账号密码、选择难度 放沉迷 登录 选择难度 游戏界面

【移除链表元素】python

目录 题目&#xff1a; 方法&#xff1a; 知识&#xff1a; 代码&#xff1a; 题目&#xff1a; 方法&#xff1a; 在头节点前增加一个虚拟头节点 知识&#xff1a; 链表中的每一个节点只包含当前值val和指向下一个next 代码&#xff1a; class Solution:def removeEle…

uniapp或微信小程序一些问题解决

1.按钮边框如何去除&#xff1f; 参考博主&#xff1a;微信小程序按钮去不掉边框_微信小程序button去掉边框-CSDN博客文章浏览阅读1k次。最近在学uni-app&#xff0c;顺便自己写个小程序。左上角放了个button&#xff0c;可边框怎么也去不掉…原来微信小程序的按钮要去掉边框要…

汽车IVI中控开发入门及进阶(二十一):DAB和FM 收音机

前言: 在过去的十年里,数字收音机对车载娱乐产生了重大影响。现在,几乎每辆新车都标配了这项技术,这也是我们60%以上的人收听收音机的方式。甚至有传言称,在不久的将来,将永久关闭调频发射机,使许多车载收音机过时。但一些相对年轻的汽车在工厂里仍然没有安装DAB,而且…

jdk1.8和jdk18的区别

JDK 1.8&#xff08;也称为Java 8&#xff09;和JDK 18是Java开发工具包&#xff08;Java Development Kit&#xff09;的两个不同版本。虽然它们都是JDK&#xff0c;但由于发布时间相差多年&#xff0c;它们在功能、性能、语言特性和工具支持等方面有显著差异。以下是它们的主…

ipv4的掩码长度到掩码地址转换

ipv4的地址用32位二进制数表示&#xff0c;为了显示方便&#xff0c;一般是按4段十进制数表示&#xff0c;每段取值范围是0-255&#xff0c;对应二进制数00000000-11111111 有些场合&#xff0c;掩码是用4段十进制数表示&#xff0c;跟ip地址一样&#xff0c;另外一些场合是用0…

模型蒸馏(distillation)

大size的teacher模型&#xff0c;训练的样本&#xff0c;最后一层softmax之前的logits&#xff0c;当作student模型的训练目标&#xff0c;损失函数是2个向量的距离&#xff1b; 原理&#xff1a;logits包含更多的信息&#xff0c;比label(也就是1-hot vector)的信息量更大&am…

六西格玛培训:企业逆袭的秘密武器!——张驰咨询

为了提升企业的运营效率、产品质量和客户满意度&#xff0c;六西格玛培训成为了一个不可或缺的环节。以下是企业成功实施六西格玛培训的关键步骤&#xff1a; 一、清晰设定培训目标 首先&#xff0c;企业应明确六西格玛培训的具体目标&#xff0c;如提升产品质量、降低成本、…

java Web开发中采用Servlet登录验证,中文用户名始终提示“用户名密码错误”以及输出中文乱码问题

采用Servlet登录验证&#xff0c;中文乱码问题解决 在Java Web开发中&#xff0c;往往采用Servlet完成前后端直接的控制和处理&#xff0c;例如&#xff1a;用户登录验证功能。 在采用如下Servle源码t完成用户名登录验证时&#xff0c;只要用户名涉及中文&#xff0c;对于正确…

【JS基础知识06】数组

一&#xff1a;数组是什么以及如何创建 1 是什么 数组是一种引用数据类型&#xff08;复杂数据类型&#xff09;&#xff0c;在数组中可以添加任何数据类型的元素 2 怎么创建 利用数组字面量的方式 let arr [数组元素] 利用new构造函数方式 let arr new Array(数组元素)…

SpringBoot 之基础(一)

文章目录 SpringBoot 基础基本概念创建 SpringBoot 项目编码编写启动类写 Controller运行 / 测试properties 和 yml关闭 Spring banner日志spring-boot 默认的日志格式 解决 start.spring.io 不能访问不使用 spring boot 的 parent pom SpringBoot 基础 Spring Boot 是由 Pivo…

梳理清楚的echarts地图下钻和标点信息组件

效果图 说明 默认数据没有就是全国地图&#xff0c; $bus.off("onresize")是地图容器变化刷新地图适配的&#xff0c;可以你们自己写 getEchartsFontSize是适配字体大小的&#xff0c;getEchartsFontSize(0.12) 12 mapScatter是base64图片就是图上那个标点的底图 Ge…

2024年5月最新高德poi数据采集科普

曾几何时&#xff0c;个人注册高德开发者即可拥有每日一万次免费配额调用&#xff0c;现如今&#xff0c;个人每日只能调用100次&#xff0c;即使额外购买了配额300元/10万次&#xff0c;也会因为短时间大量采集被封号。要想稳定采集&#xff0c;恐怕只有购买商业授权5万/年&am…

kafka的安装与简单使用

下载地址&#xff1a;Apache Kafka 1. 上传并解压安装包 tar -zxvf kafka_2.13-3.6.2.tgz 修改文件名&#xff1a;mv kafka_2.13-3.6.2 kafka 2. 配置环境变量 sudo vim /etc/profile #配置kafka环境变量 export KAFKA_HOME/export/server/kafka export PATH$PATH:$KAFKA…

【Vue】v-if / v-show条件渲染指令

条件判断指令&#xff0c;用来辅助开发者按需控制 DOM 的显示与隐藏。条件渲染指令有如下两个&#xff0c;分别是&#xff1a; v-show 作用&#xff1a; 控制元素显示隐藏&#xff08;简单的显示隐藏&#xff09; 语法&#xff1a; v-show "表达式" 表达式值为 tru…