Given two arrays arr1
and arr2
, the elements of arr2
are distinct, and all elements in arr2
are also in arr1
.
Sort the elements of arr1
such that the relative ordering of items in arr1
are the same as in arr2. Elements that do not appear in arr2
should be placed at the end of arr1
in ascending order.
Input: arr1 = [2,3,1,3,2,4,6,7,9,2,19], arr2 = [2,1,4,3,9,6]
Output: [2,2,2,1,4,3,3,9,6,7,19]
Input: arr1 = [28,6,22,8,44,17], arr2 = [22,28,8,6]
Output: [22,28,8,6,17,44]
1 <= arr1.length, arr2.length <= 1000
0 <= arr1[i], arr2[i] <= 1000
- All the elements of
arr2
are distinct. - Each
arr2[i]
is inarr1
.
class Solution:
def relativeSortArray(self, arr1: List[int], arr2: List[int]) -> List[int]:
count = [0] * 1001
for i in arr1:
count[i] += 1
pos = 0
for i in arr2:
while count[i] > 0:
arr1[pos] = i
pos += 1
count[i] -= 1
for i in range(len(count)):
while count[i] > 0:
arr1[pos] = i
pos += 1
count[i] -= 1
return arr1
class Solution {
public int[] relativeSortArray(int[] arr1, int[] arr2) {
int[] count = new int[1001];
for (int i : arr1) {
count[i]++;
}
int pos = 0;
for (int i : arr2) {
while (count[i] > 0) {
count[i]--;
arr1[pos] = i;
pos++;
}
}
for (int i = 0; i < count.length; i++) {
while (count[i] > 0) {
count[i]--;
arr1[pos] = i;
pos++;
}
}
return arr1;
}
}
function relativeSortArray(arr1: number[], arr2: number[]): number[] {
const count = new Array<number>(1001).fill(0);
for (let i of arr1) {
count[i]++;
}
let pos = 0;
for (let i of arr2) {
while (count[i] > 0) {
arr1[pos] = i;
count[i]--;
pos++;
}
}
for (let i = 0; i < count.length; i++) {
while (count[i] > 0) {
arr1[pos] = i;
count[i]--;
pos++;
}
}
return arr1;
}