-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy path2418_Sort_the_People.cpp
More file actions
37 lines (37 loc) · 1.25 KB
/
2418_Sort_the_People.cpp
File metadata and controls
37 lines (37 loc) · 1.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/*
2418. Sort the People
You are given an array of strings names, and an array heights that consists of distinct positive integers. Both arrays are of length n.
For each index i, names[i] and heights[i] denote the name and height of the ith person.
Return names sorted in descending order by the people's heights.
Example 1:
Input: names = ["Mary","John","Emma"], heights = [180,165,170]
Output: ["Mary","Emma","John"]
Explanation: Mary is the tallest, followed by Emma and John.
Example 2:
Input: names = ["Alice","Bob","Bob"], heights = [155,185,150]
Output: ["Bob","Alice","Bob"]
Explanation: The first Bob is the tallest, followed by Alice and the second Bob.
Constraints:
n == names.length == heights.length
1 <= n <= 103
1 <= names[i].length <= 20
1 <= heights[i] <= 105
names[i] consists of lower and upper case English letters.
All the values of heights are distinct.
*/
/*
MOST OPTIMIZED APPROACH
Time Complexity O(n)
Space Complexity O(n)
*/
class Solution {
public:
vector<string> sortPeople(vector<string>& names, vector<int>& heights) {
map<int,string> map;
for(int i=0;i<names.size();i++) map[heights[i]] = names[i];
names.clear();
for(auto i:map) names.push_back(i.second);
reverse(names.begin(),names.end());
return names;
}
};