day38(12.19)——leetcode面试经典150

92. 反转链表 II

92. 反转链表Ⅱ

题目:

题解:

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 cur = head;
        ListNode part = new ListNode();
        int count = 1;
        Map<Integer, ListNode> map = new HashMap<>();
        while(cur != null) {
            map.put(count++, new ListNode(cur.val));
            cur = cur.next;
        } 
        cur = new ListNode();
        ListNode h = cur;
        for(int i=1;i<left;i++) {
            cur.next = map.get(i);
            cur = cur.next;
        }
        for(int i=right;i>=left;i--) {
            cur.next = map.get(i);
            cur = cur.next;
        }
        for(int i=right+1;i<count;i++) {
            cur.next = map.get(i);
            cur = cur.next;
        }
        return h.next;
    }
}
相关推荐
甄心爱学习几秒前
【最优化】1-6章习题
人工智能·算法
PD我是你的真爱粉1 分钟前
向量数据库原理与检索算法入门:ANN、HNSW、LSH、PQ 与相似度计算
数据库·人工智能·算法
汀、人工智能3 分钟前
[特殊字符] 第72课:杨辉三角
数据结构·算法·数据库架构·图论·bfs·杨辉三角
_深海凉_13 分钟前
LeetCode热题100- 字母异位词分组
leetcode
洛水水15 分钟前
【力扣100题】14.两数相加
c++·算法·leetcode
我不是小upper16 分钟前
相关≠因果!机器学习中皮尔逊相关检验的完整流程
人工智能·算法·机器学习
float_com18 分钟前
LeetCode80. 删除有序数组中的重复项 II
leetcode
pwn蒸鱼19 分钟前
leetcode:21. 合并两个有序链表
算法·leetcode·链表
洛水水20 分钟前
【力扣100题】15.删除链表的倒数第 N 个结点
算法·leetcode·链表
蓝色的杯子21 分钟前
Python面试30分钟突击掌握-LeetCode1-Array
开发语言·python·面试