초보 개발자의 성장 일기

추억점수, reduce 본문

Development/Algorithm

추억점수, reduce

YUNA 2023. 11. 18. 13:42

문제 설명

사진들을 보며 추억에 젖어 있던 루는 사진별로 추억 점수를 매길려고 합니다. 사진 속에 나오는 인물의 그리움 점수를 모두 합산한 값이 해당 사진의 추억 점수가 됩니다. 예를 들어 사진 속 인물의 이름이 ["may", "kein", "kain"]이고 각 인물의 그리움 점수가 [5점, 10점, 1점]일 때 해당 사진의 추억 점수는 16(5 + 10 + 1)점이 됩니다. 다른 사진 속 인물의 이름이 ["kali", "mari", "don", "tony"]이고 ["kali", "mari", "don"]의 그리움 점수가 각각 [11점, 1점, 55점]]이고, "tony"는 그리움 점수가 없을 때, 이 사진의 추억 점수는 3명의 그리움 점수를 합한 67(11 + 1 + 55)점입니다.

그리워하는 사람의 이름을 담은 문자열 배열 name, 사람별 그리움 점수를 담은 정수 배열 yearning, 사진에 찍힌 인물의 이름을 담은 이차원 문자열 배열 photo 매개변수로 주어질 , 사진들의 추억 점수를 photo 주어진 순서대로 배열에 담아 return하는 solution 함수를 완성해주세요.

 

나의 문제 해결 방법

name 인덱스 번호와 yearning 인덱스 번호는 일치하니, 새로운 객체를 생성한다. 포토에 일치하는 name이 있으면 점수를 더해준다.

 

const memory = {};
  for (let i = 0; i < name.length; i++) {
    memory[name[i]] = yearning[i];
  }

객체를 만들어 이름과 점수를 저장한다.

 

return photo.map((arr) =>
    arr.reduce((acc, cur) => acc + (memory[cur] || 0), 0)
);

각 요소 배열을 reduce 메서드를 이용해 점수를 구한다. memory 객체에 해당 사람이 있으면 점수를 없으면 0을 더해준다.

 

reduce

메서드는 배열의 각 요소에 대해 주어진 리듀서 (reducer) 함수를 실행하고, 하나의 결과값을 반환한다.

reduce MDN