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;
    }
}
相关推荐
掘金安东尼13 分钟前
Fun with TypeScript Generics:玩转 TS 泛型
前端·javascript·面试
掘金安东尼14 分钟前
Next.js 企业级落地
前端·javascript·面试
掘金安东尼19 分钟前
React 性能优化完全指南 2026
前端·javascript·面试
掘金安东尼11 小时前
让 JavaScript 更容易「善后」的新能力
前端·javascript·面试
掘金安东尼11 小时前
用 HTMX 为 React Data Grid 加速实时更新
前端·javascript·面试
灵感__idea13 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
UrbanJazzerati15 小时前
非常友好的Vue 3 生命周期详解
前端·面试
想用offer打牌21 小时前
高并发下如何保证接口的幂等性
后端·面试·状态机
Wect1 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
牛奶1 天前
Vue 基础理论 & API 使用
前端·vue.js·面试