Computer Science, asked by haritha13400, 7 months ago

You are given an array A of N integers. You are allowed to choose at most one pair of elements such that distance (defined as the difference of their indices) is at most K and swap them. Your goal is to obtain the smallest lexicographical array possible. Standard input The first line contains two integers N and K. The second line contains N integers representing the elements of A. Standard output Print N integers on the first line representing the smallest lexicographical array you can obtain. Example: Input: 5 3 5 4 3 2 1 Output: 2 4 3 5 1

Answers

Answered by 5454995harinib
1

Answer:

Lexicographically smallest array after at-most K consecutive swaps

Last Updated: 17-08-2018

Given an array arr[], find the lexicographically smallest array that can be obtained after performing at maximum of k consecutive swaps.

Examples :

Input: arr[] = {7, 6, 9, 2, 1}

       k = 3

Output: arr[] = {2, 7, 6, 9, 1}

Explanation: Array is: 7, 6, 9, 2, 1

Swap 1:   7, 6, 2, 9, 1

Swap 2:   7, 2, 6, 9, 1

Swap 3:   2, 7, 6, 9, 1

So Our final array after k = 3 swaps :  

2, 7, 6, 9, 1

Input: arr[] = {7, 6, 9, 2, 1}

       k = 1

Output: arr[] = {6, 7, 9, 2, 1}

We strongly recommend that you click here and practice it, before moving on to the solution.

Naive approach is to generate all the permutation of array and pick the smallest one which satisfy the condition of at-most k swaps. Time complexity of this approach is Ω(n!), which will definitely time out for large value of n.

An Efficient approach is to think greedily. We first pick the smallest element from array a1, a2, a3…(ak or an) [We consider ak when k is smaller, else n]. We place the smallest element to the a0 position after shifting all these elements by 1 position right. We subtract number of swaps (number of swaps is number of shifts minus 1) from k. If still we are left with k > 0 then we apply the same procedure from the very next starting position i.e., a2, a3,…(ak or an) and then place it to the a1 position. So we keep applying the same process until k becomes 0.

C++

filter_none

edit

play_arrow

brightness_4

// C++ program to find lexicographically minimum  

// value after k swaps.  

#include<bits/stdc++.h>  

using namespace std ;  

 

// Modifies arr[0..n-1] to lexicographically smallest  

// with k swaps.  

void minimizeWithKSwaps(int arr[], int n, int k)  

{  

   for (int i = 0; i<n-1 && k>0; ++i)  

   {  

       // Set the position where we want  

       // to put the smallest integer  

       int pos = i;  

       for (int j = i+1; j<n ; ++j)  

       {  

           // If we exceed the Max swaps  

           // then terminate the loop  

           if (j-i > k)  

               break;  

 

           // Find the minimum value from i+1 to  

           // max k or n  

           if (arr[j] < arr[pos])  

               pos = j;  

       }  

 

       // Swap the elements from Minimum position  

       // we found till now to the i index  

       for (int j = pos; j>i; --j)  

           swap(arr[j], arr[j-1]);  

 

       // Set the final value after swapping pos-i  

       // elements  

       k -=  pos-i;  

   }  

}  

 

// Driver code  

int main()  

{  

   int arr[] = {7, 6, 9, 2, 1};  

   int n = sizeof(arr)/sizeof(arr[0]);  

   int k = 3;  

 

   minimizeWithKSwaps(arr, n, k);  

 

   //Print the final Array  

   for (int i=0; i<n; ++i)  

       cout << arr[i] <<" "; }

Similar questions