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

Leetcode面试经典150题-92.反转链表II

  解法都在代码里,不懂就留言或者私信

比反转链表I略微难一点点

/**
 * 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 {
    /**反转链表1的难度升级版,注意处理边界条件 */
    public ListNode reverseBetween(ListNode head, int left, int right) {
        /**根据题目的设定,left一定小于等于right并且在有效范围内
        所以链表只有一个节点的时候肯定就是left==right==1,这种也包含在我们的if内 */
        if(left == right) {
            return head;
        }
        /**寻找反转区间的前置节点和后驱节点*/
        ListNode rangePre = null;
        ListNode rangePost = head;
        ListNode cur = head;
        while(left> 1) {
            rangePost = cur.next;
            left --;
            right --;
            rangePre = cur;
            cur = rangePost;
        }
        /**这里的rangePre是我们要反转的区间的前一个节点,继续寻找后继节点*/
        while(right > 1) {
            rangePost = cur.next;
            right --;
            cur = rangePost;
        }
        ListNode rangeStart = head;
        /**出循环的时候rangPost就是整个区间的最后一个节点,不管前驱还是后继,都是有可能为空的,连接的时候要注意判断 */
        if(rangePre != null) {
            /**如果rangePre是null,那rangeStart就是head */
            rangeStart = rangePre.next;
            rangePre.next = null;
        }
        /**拿到当前区间后面的第一个节点*/
        ListNode rangeNext = rangePost.next;
        /**断开和后面的连接 */
        rangePost.next = null;
        ListNode newRangeHead = reverse(rangeStart);
        /**如果rangePre不是null,连接新的头*/
        if(rangePre != null) {
            rangePre.next = newRangeHead;
        }
        rangeStart.next = rangeNext;
        return rangePre != null? head : newRangeHead;
    }

    /**经典的反转链表 */
    public ListNode reverse(ListNode head) {
        ListNode pre = null;
        ListNode next = null;
        ListNode cur = head;
        while(cur != null) {
            next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
        return pre;
    }
}


http://www.kler.cn/a/294302.html

相关文章:

  • React Hooks在现代前端开发中的应用
  • Elasticsearch 8.16:适用于生产的混合对话搜索和创新的向量数据量化,其性能优于乘积量化 (PQ)
  • 鸿蒙学习基本概念
  • Linux基础1
  • Thread类及常见方法
  • 【MySQL 保姆级教学】事务的隔离级别(详细)--下(13)
  • 传统CV算法——基于Opencv的图像绘制
  • QT:QWidget 控件属性的介绍
  • 数据结构刷题
  • python容器1-列表
  • pytorch torch.matmul函数介绍
  • 网络堡垒:交换机加固,守护你的数据安全
  • 10,sql约束(2)
  • 算法习题集
  • C++入门(05-2)从命令行执行C++编译器_GCC
  • 套接字的介绍
  • 2024 年高教社杯全国大学生数学建模竞赛 C 题 农作物的种植策略(完整代码)
  • 【无标题】XSS安全防护:responseBody (输入流可重复读) 配置
  • 搭建 canal 监控mysql数据到 elasticsearch 中(本机到远端sql)
  • linux挂盘
  • Axure中继器教程及案例详解
  • 使用http-request 属性替代action绑定上传URL
  • 在鼠标附近显示一个中心渐变色的高亮效果
  • 流媒体技术革新,EasyCVR视频汇聚平台赋能视频监控全面升级
  • Go入门指南(The Way to Go) 完整版PDF
  • ARM SIMD instruction -- fcmpe