다음과 같은 일부 중복 값을 포함하는 문자열/숫자 리터럴 배열이 있다고 가정해 보겠습니다. -
const array = ['day', 'night', 'afternoon', 'night', 'noon', 'night', 'noon', 'day', 'afternoon', 'day', 'night'];
이 배열을 가져와서 모든 반복 항목이 하위 배열에서 첫 번째 요소로 그룹화되고 원래 배열의 총 개수가 두 번째 요소인 새 배열을 반환하는 함수 groupSimilar()를 작성해야 합니다.
따라서 이 예의 경우 출력은 -
여야 합니다.[ [ 'day', 3 ], [ 'night', 4 ], [ 'afternoon', 2 ], [ 'noon', 2 ] ]
이 함수에 대한 코드를 작성해 봅시다. 우리는 Array.prototype.map() 함수를 사용하여 새로운 필수 배열을 구성하고 Map을 사용하여 배열의 반복 항목을 추적합니다 -
예시
const array = ['day', 'night', 'afternoon', 'night', 'noon', 'night', 'noon', 'day', 'afternoon', 'day', 'night']; const groupSimilar = arr => { return arr.reduce((acc, val) => { const { data, map } = acc; const ind = map.get(val); if(map.has(val)){ data[ind][1]++; } else { map.set(val, data.push([val, 1])-1); } return { data, map }; }, { data: [], map: new Map() }).data; }; console.log(groupSimilar(array));
출력
콘솔의 출력은 다음과 같습니다. -
[ [ 'day', 3 ], [ 'night', 4 ], [ 'afternoon', 2 ], [ 'noon', 2 ] ]