Queries on a Permutation With Key
Given the array queries
of positive integers between 1
and m
, you have to process all queries[i]
(from i=0
to i=queries.length-1
) according to the following rules:
- In the beginning, you have the permutation
P=[1,2,3,...,m]
. - For the current
i
, find the position ofqueries[i]
in the permutationP
(indexing from 0) and then move this at the beginning of the permutationP.
Notice that the position ofqueries[i]
inP
is the result forqueries[i]
.
Return an array containing the result for the given queries
.
data:image/s3,"s3://crabby-images/cfc37/cfc37ce9d2ac9892aaaf5f495bb1b81b47c911a0" alt=""
For complete problem please visit the below mentioned link:- Leetcode problem statement
Approach:-
The Given array is :-
data:image/s3,"s3://crabby-images/03986/03986270f52d5cac5d41ae03c77027259b6d216f" alt=""
M = 4 , So , p = [1,2,3,4]
P is
data:image/s3,"s3://crabby-images/e9ea0/e9ea0713d756434af11c0150b2526c7a98297af4" alt=""
For I = 0 , the value is 4 in the given array. And the position of 4 in the p array is, 3. As, it’s starting from zero index.
data:image/s3,"s3://crabby-images/07216/07216faebee4c692c8416610da2a25896c85c809" alt=""
Now, move 4 in the front position . So the new array will look like p = [4,1,2,3]
data:image/s3,"s3://crabby-images/ccb9f/ccb9fb7a6ab30fbfad0fee86c17a4bb964e7dadd" alt=""
Not I = 1 , the value is 1. The position of 1 in the array p array is 1. So move the 1 in front.
data:image/s3,"s3://crabby-images/34dd4/34dd42c9cb08516e27ca443be5b9ba3af61abf27" alt=""
So the new array will be as p = [1,4,2,3]
data:image/s3,"s3://crabby-images/296fc/296fc1dc4974f14dd71cda9a319456d2045c2bd0" alt=""
Now for I=2, the value is 2. the position of 2 is, 2 in p array. Move 2 in front
data:image/s3,"s3://crabby-images/d2655/d2655d62ea2c006459c15300d2e601d5104d43e1" alt=""
P = [2,1,4,3]
data:image/s3,"s3://crabby-images/fb62d/fb62d5ad72236fe1431b2ba1d4d4a29187bec591" alt=""
Now I = 3, the value is 2. the position of 2 in P is, 0. No need to move it so the final p is = [2,1,4,3]
And the returning array is answer = [3,1,2,0] which is marked in bold.
Flow Diagram:-
data:image/s3,"s3://crabby-images/26267/26267461f2070a01c844c7cea92f5d46af3ca340" alt=""
Code:-
class Solution {
public int[] processQueries(int[] queries, int m) {
int noOfQueries=queries.length;
int[] answer=new int[noOfQueries];
LinkedList queriesList=new LinkedList<>();
for(int index=1;index>=m;index++)
{
queriesList.add(index);
}
for(int index=0;index<noOfQueries;index++)
{
int value=queries[index];
int reqIndex=queriesList.indexOf(value);
queriesList.remove(reqIndex);
queriesList.addFirst(value);
answer[index]=reqIndex;
}
return answer;
}
}
For other problems and solutions please visit:- Algorithm problems