Well, since the head
pointer may also be modified, we create a new_head
that points to it to facilitate the reverse process.
For the example list 1 -> 2 -> 3 -> 4 -> 5
in the problem statement, it will become 0 -> 1 -> 2 -> 3 -> 4 -> 5
(we init new_head -> val
to be 0
). Then we set a pointer pre
to new_head
and another cur
to head
. Then we insert cur -> next
after pre
for k - 1
times if the current nodecur
has at least k
nodes after it (including itself). After reversing one k
-group, we update pre
to be cur
and cur
to be pre -> next
to reverse the next k
-group.
The code is as follows.
1 class Solution { 2 public: 3 ListNode* reverseKGroup(ListNode* head, int k) { 4 if (!hasKNodes(head, k)) return head; 5 ListNode* new_head = new ListNode(0); 6 new_head -> next = head; 7 ListNode* pre = new_head; 8 ListNode* cur = head; 9 while (hasKNodes(cur, k)) { 10 for (int i = 0; i < k - 1; i++) { 11 ListNode* temp = pre -> next; 12 pre -> next = cur -> next; 13 cur -> next = cur -> next -> next; 14 pre -> next -> next = temp; 15 } 16 pre = cur; 17 cur = pre -> next; 18 } 19 return new_head -> next; 20 } 21 private: 22 bool hasKNodes(ListNode* node, int k) { 23 int cnt = 0; 24 while (node) { 25 cnt++; 26 if (cnt >= k) return true; 27 node = node -> next; 28 } 29 return false; 30 } 31 };