반복되는 값을 갖는 리터럴 배열을 취하는 JavaScript 함수를 작성해야 합니다. 우리의 함수는 배열에서 가장 일반적인 요소의 배열을 반환해야 합니다(두 개 이상의 요소가 동일한 횟수로 가장 많이 나타나는 경우 배열에는 해당 요소가 모두 포함되어야 함).
예시
이에 대한 코드는 -
const arr1 = ["a", "c", "a", "b", "d", "e", "f"]; const arr2 = ["a", "c", "a", "c", "d", "e", "f"]; const getMostCommon = arr => { const count = {}; let res = []; arr.forEach(el => { count[el] = (count[el] || 0) + 1; }); res = Object.keys(count).reduce((acc, val, ind) => { if (!ind || count[val] > count[acc[0]]) { return [val]; }; if (count[val] === count[acc[0]]) { acc.push(val); }; return acc; }, []); return res; } console.log(getMostCommon(arr1)); console.log(getMostCommon(arr2));
출력
콘솔의 출력은 -
[ 'a' ] [ 'a', 'c' ]