다음과 같은 객체 배열이 있다고 가정해 보겠습니다. -
const arr = [
{a:1, b:"apples"},
{a:3, b:"apples"},
{a:4, b:"apples"},
{a:1, b:"bananas"},
{a:3, b:"bananas"},
{a:5, b:"bananas"},
{a:6, b:"bananas"},
{a:3, b:"oranges"},
{a:5, b:"oranges"},
{a:6, b:"oranges"},
{a:10, b:"oranges"}
]; 우리는 그러한 배열을 취하고 객체의 배열을 반환하는 JavaScript 함수를 작성해야 합니다.
배열은 "a" 속성이 가장 높은 값을 갖는 "b" 속성의 각 고유 값에 대한 개체를 포함해야 합니다.
이에 대한 코드는 -
const arr = [
{a:1, b:"apples"},
{a:3, b:"apples"},
{a:4, b:"apples"},
{a:1, b:"bananas"},
{a:3, b:"bananas"},
{a:5, b:"bananas"},
{a:6, b:"bananas"},
{a:3, b:"oranges"},
{a:5, b:"oranges"},
{a:6, b:"oranges"},
{a:10, b:"oranges"}
];
const pickHighest = arr => {
const res = [], map = {};
arr.forEach(el => {
if (!(el['b'] in map)) {
map[el['b']] = res.push(el) - 1;
return;
};
if(res[map[el['b']]]['a'] < el['a']){
res[map[el['b']]] = el;
};
});
return res;
};
console.log(pickHighest(arr)); 다음은 콘솔의 출력입니다 -
[
{ a: 4, b: 'apples' },
{ a: 6, b: 'bananas' },
{ a: 10, b: 'oranges' }
]