題目:1122. 數組的相對排序
給你兩個數組,arr1 和 arr2,
- arr2 中的元素各不相同
- arr2 中的每個元素都出現在 arr1 中
對 arr1 中的元素進行排序,使 arr1 中項的相對順序和 arr2 中的相對順序相同。未在 arr2 中出現過的元素需要按照升序放在 arr1 的末尾。
示例:
輸入:arr1 = [2,3,1,3,2,4,6,7,9,2,19], arr2 = [2,1,4,3,9,6]
輸出:[2,2,2,1,4,3,3,9,6,7,19]
提示:
- arr1.length, arr2.length <= 1000
- 0 <= arr1[i], arr2[i] <= 1000
- arr2中的元素 arr2[i] 各不相同
- arr2 中的每個元素 arr2[i] 都出現在 arr1 中
class Solution {
public:
vector<int> relativeSortArray(vector<int>& arr1, vector<int>& arr2) {
}
};
思路:
還是排序問題,記錄arr1中同樣數字出現的次數,先依據arr2中的數字序列查找,找到就把對應值的個數全部輸出,再把剩下的由小到大排列。
class Solution {
public:
vector<int> relativeSortArray(vector<int>& arr1, vector<int>& arr2) {
unordered_map<int, int> rank;
for (int i = 0; i < arr2.size(); ++i)
rank[arr2[i]] = i;
sort(arr1.begin(), arr1.end(), [&](int x, int y) {
if (rank.count(x))
return rank.count(y) ? rank[x] < rank[y] : true;
else
return rank.count(y) ? false : x < y;
});
return arr1;
}
};
周六加班到第二天忘記打卡可還行,補卡-1,加油,睡了睡了。
本來想白天再寫的,但是瞅了一眼居然是簡單題,自己也能有點思路,和官方題解還能對上點,就偷懶先發出來(隻要沒睡,這一天就還沒過去。)