Leetcode-92:Reverse Linked List II
LeetCode-92: Reverse Linked List II
Question
Given the head
of a singly linked list and two integers left
and right
where left <= right
, reverse the nodes of the list from position left
to position right
, and return the reversed list.
Example 1:
data:image/s3,"s3://crabby-images/2f1cc/2f1ccdfa93981a3a6dc777e2ac02de3f73d65824" alt="img"
Input: head = [1,2,3,4,5], left = 2, right = 4
Output: [1,4,3,2,5]
Example 2:
Input: head = [5], left = 1, right = 1
Output: [5]
Constraints:
- The number of nodes in the list is
n
. 1 <= n <= 500
-500 <= Node.val <= 500
1 <= left <= right <= n
Follow up: Could you do it in one pass?
Thoughts
- We just need to partially reverse the LinkedList.
- Left & Right position are recorded by Int value.
- If we can record head and tail and just reverse the part which needs to be reversed.
- How to reverse a linkedlist?
Solution
Reverse sequentially
Take an example of list below:
Core:
- Find the head node and tail node position in the node part which we want to do reverse.
- Find the node before head (oFront node
7
) and after tail(oTail node6
), cause we need to use it to refracture a linkedlist. - Reverse the inner linkedlist sequentially, with head becoming the tail and tail becoming the head.
- Refacture the whole linkedlist with inner list(Link the inner list with oFront node and oTail node).
Extreme Cases
Notice that in some cases, the oFront/oTail might be null.
For example, left = 1 || right = 7, so we might handle these cases extra.
data:image/s3,"s3://crabby-images/fbb08/fbb08ba17ea08f9b066fa5bdfe6ef0905de3cbf4" alt=""
/**
* 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 prev = null;
ListNode front = null;
ListNode tail = null;
ListNode oFront = null;
int count = 0;
ListNode next;
if (left == right) {
return head;
}
while (count <= right) {
count++;
if (count <= left) {
// record head and oFront
if (count == left) {
front = cur;
oFront = prev;
}
// Normal Forward
prev = cur;
cur = cur.next;
} else {
// reverse sequentially
next = cur.next;
cur.next = prev;
prev = cur;
cur = next;
if (count == right) {
tail = prev;
// Check oFront exist? (if left != 1)
if (oFront != null) {
oFront.next = tail;
}
front.next = cur;
// handle extreme cases
if (cur == null && oFront == null) {
return tail;
} else if (cur == null) {
return head;
} else if (oFront == null) {
return tail;
} else {
break;
}
}
}
}
return head;
}
}
data:image/s3,"s3://crabby-images/21e74/21e747f699310bc62f2682a135565301a5dd0e64" alt=""
Complexity Analysis
Time-Complexity:
Zone-Complexity:
Reverse by head insertion (Copy)
©️ Copied
📝 Praticed ✅
Core: Same as reverse sequentially, only difference is reverse by head insertion.
data:image/s3,"s3://crabby-images/8f325/8f3250ca6616e954609e7081fd11e19c78a502c0" alt=""
/**
* 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 preHead = new ListNode(-1);
preHead.next = head;
ListNode prev = preHead;
for (int i = 0; i < left - 1; i++) {
prev = prev.next;
}
ListNode cur = prev.next;
for (int i = 0; i < right - left; i++) {
ListNode next = cur.next;
cur.next = next.next;
next.next = prev.next;
prev.next = next;
}
return preHead.next;
}
}
data:image/s3,"s3://crabby-images/83c77/83c7782f7b934d205d8069daf9ac2fccd0802c45" alt=""
Complexity Analysis
Time-Complexity:
Zone-Complexity:
Reflection
Reverse the LinkedList
Talking to reverse linkedlist, there are always two ways to do the reverse.
- Reverse sequently.
- Reverse by head insertion.
But keep this in mind, both ways need three parts to do that.
Prev Cur Next
What we really need to do, is to make the order of Assignment Process clear.