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

力扣:92. 反转链表 II(Java)

目录

  • 题目描述:
  • 示例 1:
  • 示例 2:
  • 代码实现:

题目描述:

给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 。

示例 1:

输入:head = [1,2,3,4,5], left = 2, right = 4
输出:[1,4,3,2,5]
在这里插入图片描述

示例 2:

输入:head = [5], left = 1, right = 1
输出:[5]

代码实现:

/*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val) { this.val = val; }* ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode reverseBetween(ListNode head, int left, int right) {ListNode tmp = new ListNode(-1);// 设置哑结点tmp.next = head;// 哑结点指向头节点// pre指向哑结点ListNode pre = tmp;// 使pre指向反转链表的前一个结点for (int i = 0; i < left - 1; i++) {pre = pre.next;}ListNode rightNode = pre;// 记录反转链表的前一个结点for (int i = 0; i < right - left + 1; i++) {rightNode = rightNode.next;// 找到反转链表的尾结点}ListNode leftNode = pre.next;// 记录反转链表的头节点ListNode endList = rightNode.next;// 记录反转链表的后一个结点// 断开原来链表:将需要反转的链表切割开pre.next = null;// 切割头节点rightNode.next = null;// 切割尾结点// 反转链表操作reverseLinkedList(leftNode);// 连接链表操作pre.next = rightNode;// 原先反转链表的前驱 指向 现在反转之后的链表的右节点(也就是现在的头节点)leftNode.next = endList;// 反转之后的链表左节点(也就是现在的尾结点) 指向 原先反转链表的后继// 返回哑结点的后继return tmp.next;// 这里不返回head结点的原因是:在反转操作时,head已经指向反转链表的尾结点了}// 反转函数反转了结点之间的指向,head指向的是反转之后的尾结点void reverseLinkedList(ListNode head) {ListNode cur = head;// 头节点开始遍历ListNode pre = null;// 前驱结点while (cur != null) {ListNode next = cur.next;// 记录后继结点cur.next = pre;// 结点指向前驱pre = cur;// 前驱指针指向当前结点cur = next;// 当前指针指向后继结点}}
}
http://www.lryc.cn/news/356497.html

相关文章:

  • [less配置]vue2引入less
  • 物理内存与虚拟内存的区别
  • MySQL数据库案例实战教程:数据类型、语法与高级查询详解
  • 操作系统——用户态与内核态、同步与异步、阻塞与阻塞
  • C# VSTO读取Excel单元格Value、Value2
  • 如何快速从手动测试转向自动化测试
  • 【Linux+Docker】修改Docker容器中的hosts文件
  • 在VS Code中进行Java的单元测试
  • 国内信创web中间件生态
  • CSS中的writing-mode属性:解锁文本布局新维度
  • SQL面试题练习 —— 波峰波谷
  • 检索模型预训练方法:RetroMAE
  • OpenHarmony实战开发——宿舍全屋智能开发指南
  • 等了10年,终于迎来RTX5/RTX4全家桶开源,开源,开源! 且免费商用
  • Python 读取.shp文件并生成图幅编号
  • 【算法】位运算算法——判断字符是否唯一
  • AAAI2024 基于扩散模型 多类别 工业异常检测 DiAD
  • JavaEE-Spring Controller(服务器控制以及Controller的实现和配置)
  • 页面导出PDF,非可视区域如何解决
  • Android UI:ViewTree: 监听
  • 【光伏干货】光伏无人机巡检步骤
  • 『大模型笔记』从头开始代码构建GPT!
  • idea的project structure下project [lauguage ]()level 没有java的sdk17选项如何导入
  • JavaScript数据类型与转换
  • 三十、openlayers官网示例解析Double click, Drag and Zoom——第二次点击鼠标拖拽缩放地图效果、取消地图双击放大事件
  • 前端基础入门三大核心之网络安全篇:TLS/SSL的魔法之旅
  • Flutter 中的 SnackBarAction 小部件:全面指南
  • Point-Nerf 理论笔记和理解
  • 深度学习中的梯度消失和梯度爆炸问题
  • Flink 通过 paimon 关联维表,内存降为原来的1/4