【java】力扣 反转链表II

文章目录

反转链表II

网址 反转链表II

题目介绍

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

题目讲解

对于这个题,利用哨兵节点会更好理解一些

让哨兵节点去当头结点的前一个节点

然后再定义两个节点pre、cur

反转最后应该是这样

因为题目说left是节点反转开始的位置
我们需要找到节点开始反转开始的前一个节点 来进行反转
所以要循环left-1次

那为什么要找到反转节点的前一个节点呢?

以1,2,3,4,5 left=2,right=4为例

反转2-4 反转成功后,1后面是4,而5前面是2,所以需要1的辅助来进行反转,以确保反转的成功性

反转过程与整个反转类似 详细请看
力扣 反转链表I

下面就是代码展示:

java 复制代码
/**
 * 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 dummy = new ListNode(0,head);//定义一个哨兵节点
    ListNode p0 = dummy;
    for(int i =0;i<left-1;i++){
        p0 = p0.next;//
    }  
    ListNode pre = null;
    ListNode cur = p0.next;
    for(int i =0;i<right-left+1;i++){
        ListNode nxt = cur.next;
        cur.next = pre;
        pre = cur;
        cur = nxt;
    }
    p0.next.next = cur;
    p0.next = pre;
    return dummy.next;
    
    }
}
相关推荐
drebander11 分钟前
使用 Java Stream 优雅实现List 转化为Map<key,Map<key,value>>
java·python·list
乌啼霜满天24915 分钟前
Spring 与 Spring MVC 与 Spring Boot三者之间的区别与联系
java·spring boot·spring·mvc
tangliang_cn20 分钟前
java入门 自定义springboot starter
java·开发语言·spring boot
莫叫石榴姐21 分钟前
数据科学与SQL:组距分组分析 | 区间分布问题
大数据·人工智能·sql·深度学习·算法·机器学习·数据挖掘
程序猿阿伟21 分钟前
《智能指针频繁创建销毁:程序性能的“隐形杀手”》
java·开发语言·前端
Grey_fantasy31 分钟前
高级编程之结构化代码
java·spring boot·spring cloud
弗锐土豆37 分钟前
工业生产安全-安全帽第二篇-用java语言看看opencv实现的目标检测使用过程
java·opencv·安全·检测·面部
Elaine20239138 分钟前
零碎04 MybatisPlus自定义模版生成代码
java·spring·mybatis
小小大侠客1 小时前
IText创建加盖公章的pdf文件并生成压缩文件
java·pdf·itext
一二小选手1 小时前
【MyBatis】全局配置文件—mybatis.xml 创建xml模板
xml·java·mybatis