๋ฌธ์
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.
์ ๊ทผ๋ฐฉ๋ฒ
์ด๋ฆ ๋ฐฐ์ด๊ณผ ํค๊ฐ ๋ด๊ธด ๋ฐฐ์ด์ด ์ฃผ์ด์ง๊ณ , ๊ฐ ์ธ๋ฑ์ค ์๋ฆฌ์ ์์๋ค์ด ํ์ด์ด๋ค.
ํค๋ฅผ ๋ด๋ฆผ์ฐจ์์ผ๋ก ์ ๋ ฌํ ์ด๋ฆ์ ๋ฐฐ์ด๋ก ๋ฐํํ๋ผ๋๊ฒ ๋ฌธ์ ์ ์์ง์ด๋ค.
๊ฐ๊ฐ์ ๋ฐฐ์ด์ ๊ฐ์ฒด๋ก ํฉ์ณ์ ๊ทธ ๊ฐ์ฒด์ ํค value ๊ฐ์ sortํด์ key๊ฐ์ ๋ฐํํ๋ฉด ๋๊ฒ ๋ค๋ผ๊ณ ์๊ฐํ๋ค.
object๋ก ๋ง๋ค๊ณ sortํ๊ธฐ ์ํด ๊ทธ๊ฑธ 2์ค ๋ฐฐ์ด๋ก ๋ค์ ๋ง๋ค์ด์ผํจ. ...... ๋ณต์กํ๋ฐ..?...
์ฒซ ์๋๋ ์คํจ๋ฅผ ํ๋๋ฐ, key๊ฐ์ name์ผ๋ก ํ๊ณ value ์๋ฆฌ์ height๋ฅผ ๋ฃ์๋๋ฐ, ๋๋ช ์ธ์ด ์์ผ๋ฉด ์ ๋๋ก ์๋ฃ๊ฐ ์๋ค์ด๊ฐ๋ ๊ฒ์ด๋ค!!
๊ทธ๋์ heights๋ฅผ key๋ก ํด์ ์ด๋ฆ์ value๋ฅผ ๋ฃ๊ณ ๋ค์ sort๋ฅผ ํ๋ค.
์ฝ๋
var sortPeople = function(names, heights) {
let ob = {}
let result = []
heights.map((h, i) => {
ob[h] = names[i]
})
var sortable = [];
for (let name in ob) {
sortable.push([name, ob[name]]);
}
sortable
.sort((a, b) => b[0] - a[0])
.map((name) => {
result.push(name[1])
})
return result
};
๋ค๋ฅธ ์๋ฃจ์
let output = []
// let's concatenate the arrays to sort later
for (let i in heights) {
output.push({name: names[i], height: heights[i]})
}
return output
.sort((a,b) => b.height - a.height) // sort
.map(i => i.name) // cut needed
'๊ฐ๋ฐ > ๐ฌ ์ฝ๋ฉํ ์คํธ' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[leetCode/Javascript] 2363. Merge Similar Items (0) | 2024.02.27 |
---|---|
[leetCode/Javascript] 1572. Matrix Diagonal Sum (0) | 2024.02.13 |
[LeetCode/Javascript] 216. Combination Sum III (0) | 2024.02.05 |
[leetCode/javascript] 1071. Greatest Common Divisor of Strings (0) | 2024.02.02 |
[leetCode] 151. Reverse Words in a String - Javascript (0) | 2024.02.02 |