# Partitioning a linked list around a given value and If we don’t care about making the elements of the list “stable”

Given a linked list and a value x, partition a linked list around a value x, such that all nodes less than x come before all nodes greater than or equal to x. If x is contained within the list the values of x only need to be after the elements less than x (see below). The partition element x can appear anywhere in the “right partition”; it does not need to appear between the left and right partitions.

Examples:

```Input :  3 -> 5 -> 10 -> 2 -> 8 -> 2 -> 1
x = 5
Output : 1-> 2-> 2-> 3-> 5-> 10-> 8
```

## Recommended: Please try your approach on {IDE} first, before moving on to the solution.

If we don’t care about making the elements of the list “stable” then we can instead rearrange the elements by growing the list at the head and tail.

In this approach, we start a “new” list (using the existing nodes). Elements bigger than the pivot element are put at the tail and elements smaller are put at the head. Each time we insert an element, we update either the head or tail.

Below is C++ implementation of above idea.

```// C++ program to partition a linked list around a
// given value.
#include<bits/stdc++.h>
using namespace std;

struct Node
{
int data;
struct Node* next;
};

// A utility function to create a new node
Node *newNode(int data)
{
struct Node* new_node = new Node;
new_node->data  = data;
new_node->next = NULL;
return new_node;
}

// Function to make a new list(using the existing
// nodes) and return head of new list.
struct Node *partition(struct Node *head, int x)
{
/* Let us initialize start and tail nodes of
new list */

// Now iterate original list and connect nodes
while (curr != NULL)
{
struct Node *next = curr->next;
if (curr->data < x)
{
/* Insert node at head. */
}

else // Append to the list of greater values
{
/* Insert node at tail. */
tail->next = curr;
tail = curr;
}
curr = next;
}
tail->next = NULL;

// The head has changed, so we need
// to return it to the user.
}

/* Function to print linked list */
{
while (temp != NULL)
{
printf("%d  ", temp->data);
temp = temp->next;
}
}

// Driver program to run the case
int main()
{

int x = 5;
return 0;
}
```

Output:

```1  2  2  3  5  8  10
```

This article is contributed by Mr. Somesh Awasthi. If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

# GATE CS Corner    Company Wise Coding Practice

Please write to us at contribute@geeksforgeeks.org to report any issue with the above content.
3.2 Average Difficulty : 3.2/5.0
Based on 7 vote(s)