This post is completed by 2 users
|
Add to List |
186. Reverse a Linked List in groups of given size 'K'
Objective: Given a linked list and integer 'k', write an algorithm to reverse the linked list in groups of size 'k'.
Example:
data:image/s3,"s3://crabby-images/69212/69212895f1af8b9a4380f906579e2f33c29a5162" alt="Reverse a Linked List in groups of given size 'K' Example"
Approach:
- Earlier we have seen how to reverse a linked list, solution for reverse the linked list in groups of size will be extension of this solution.
- Reverse first 'k' nodes of the linked list, the kth node will be a new head, return it.
- Make a recursive call to rest of the list and attach it to the last node.(See the picture below)
data:image/s3,"s3://crabby-images/0e934/0e934291b5f37e1321af500d280ee2db17e9573a" alt="Reverse a Linked List in groups of given size 'K'"
Output:
->3->2->1->6->5->4->8->7