Partition
Quick sort is based on the Divide-and-conquer approach. In QuickSort(A, p, r), first, a procedure Partition(A, p, r) divides an array A[p..r] into two subarrays A[p..q-1]and A[q+1..r] such that each element of A[p..q-1] is less than or equal to A[q], which is, inturn, less than or equal to each element of A[q+1..r]. It also computes the index q.
In the conquer processes, the two subarrays A[p..q-1]and A[q+1..r] are sorted by recursive calls of QuickSort(A, p, q-1)andQuickSort(A, q+1, r).
Your task is to read a sequence A and perform the Partition based on the following pseudocode:Partition(A, p, r)1 x = A[r]2 i = p-13for j = p to r-14doif A[j]<= x
5 then i = i+16 exchange A[i]and A[j]7 exchange A[i+1]and A[r]8return i+1
Note that, in this algorithm, Partition always selects an element A[r] as a pivot element around which to partition the array A[p..r].
Input
The first line of the input includes an integer n, the number of elements in the sequence A.
In the second line, Ai (i =1,2,...,n), elements of the sequence are given separated by space characters.
Output
Print the sorted sequence. Two contiguous elements of the sequence should be separated by a space character. The element which is selected as the pivot of the partition should be indicated by [].
Constraints
1 ≤ n ≤ 100,0000 ≤ Ai ≤ 100,000
Sample Input 11213199512874212611
Sample Output 19587426[11]21131912