Skip to content

Latest commit

 

History

History
48 lines (38 loc) · 1.12 KB

File metadata and controls

48 lines (38 loc) · 1.12 KB
Screenshot 2023-10-21 at 4 16 55 AM

1 -> 2 -> 3 -> 4 -> 5

1 -> 3 -> 2 -> 4 -> 5

1 -> 4 -> 3 -> 2 -> 5

/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
 * @param {ListNode} head
 * @param {number} left
 * @param {number} right
 * @return {ListNode}
 */
var reverseBetween = function(head, left, right) {
    // Initialize dummy node to handle edge cases.
    let dummyHead = new ListNode();
    dummyHead.next = head;
    let prev = dummyHead;

    // 1. Traverse to the node just before 'left'
    for (let i = 0; i < left - 1; i++) {
        prev = prev.next;
    }

    let current = prev.next;

    // 2. Reverse the segment from 'left' to 'right'
    for (let i = 0; i < right - left; i++) {
        let next = current.next;
        current.next = next.next;
        next.next = prev.next;
        prev.next = next;
    }

    return dummyHead.next;
};