LeetCode第92题反转链表 II

继续打卡算法题,今天学习的是LeetCode第92题反转链表 II,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

本题是反转链表的升级版本,本题需要反转指定位置区间的链表段,我们只需要记录一下反转链表段的头部和尾部,还有前一个指针和后一个指针,等反转结束后将记录的重新指向反转后的指向即可。

这种做法比较容易理解。通过4个指针记录了反转链表关键的位置。

本题解题技巧

1、通过4个指针记录反转链表的头,尾,和前序和后继节点,代码实现比较好理解。

编码解决

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) {

        if(left == right) {
            return head;
        }

        //虚拟头节点
        ListNode dumy = new ListNode();
        dumy.next = head;

        //记录待反转的前一个节点指针。
        ListNode pre = null;
        ListNode next = null;

        ListNode pre1 = null;

        //记录反转链表的头尾节点
        ListNode start = null;
        ListNode end = null;

        int index = 0;

        //遍历到的节点
        ListNode curr = dumy;
        while(curr != null) {
           // System.out.println(curr.val);
            ListNode temp =  curr.next;
            if(index == left-1) {
                pre = curr;
            }

            if(index == left) {
                start = curr;
            }

            if(index == right) {
                end = curr;
                
            }

            if(index == right + 1) {
                next = curr;
                
            }

            //开始反转
            if(index > left && index <= right) {
                //System.out.println(curr.val);
               curr.next = pre1;
               
            }

            //反转完成的时候
            if(index == right || index > right) {
                pre.next = end;
                //System.out.println(next);
                start.next = next;
            }

            pre1 = curr;
            curr = temp;

            index ++;
            System.out.println("index"+index);

        }

        return dumy.next;
    }
}

总结

1、反转链表题目,本身不难理解,但是代码实现层面需要更新节点指向,这个在编码过程中是比较难控制的。

相关推荐
码事漫谈21 小时前
快速入门现代C++:从C++11到C++20的核心特性
后端
码事漫谈21 小时前
深入解析进程间通信(IPC)及其应用场景
后端
ejinxian21 小时前
ASP.NET Core 10
后端·asp.net·core 10
源码之家21 小时前
机器学习:基于大数据二手房房价预测与分析系统 可视化 线性回归预测算法 Django框架 链家网站 二手房 计算机毕业设计✅
大数据·算法·机器学习·数据分析·spark·线性回归·推荐算法
Lv Jianwei21 小时前
Longest Palindromic Substring最长回文子串-学习动态规划Dynamic Programming(DP)
算法
用户214118326360221 小时前
Claude Skills 硬核技巧:用 PDF-Skill 10 分钟搞定全类型 PDF 自动化,办公人必备
后端
WWZZ202521 小时前
快速上手大模型:深度学习7(实践:卷积层)
人工智能·深度学习·算法·机器人·大模型·卷积神经网络·具身智能
大橙子打游戏1 天前
mp4文件在CDN上无法在网页播放的问题
后端
l1t1 天前
用SQL求解advent of code 2024年23题
数据库·sql·算法
10岁的博客1 天前
二维差分算法高效解靶场问题
java·服务器·算法