[프로그래머스 0레벨] 등수 매기기 (배열 원소들의 등수로 이루어진 배열을 반환)

이민선(Jasmine)·2022년 12월 15일
0
post-thumbnail
영어 점수와 수학 점수의 평균 점수를 기준으로 학생들의 등수를 매기려고 합니다. 영어 점수와 수학 점수를 담은 2차원 정수 배열 score가 주어질 때, 영어 점수와 수학 점수의 평균을 기준으로 매긴 등수를 담은 배열을 return하도록 solution 함수를 완성해주세요.


제한사항
0 ≤ score[0], score[1] ≤ 100
1 ≤ score의 길이 ≤ 10
score의 원소 길이는 2입니다.
score는 중복된 원소를 갖지 않습니다.

입출력 예
                   score	                                                    result
[[80, 70], [90, 50], [40, 70], [50, 80]]	                                [1, 2, 4, 3]
[[80, 70], [70, 80], [30, 50], [90, 100], [100, 90], [100, 100], [10, 30]]	[4, 4, 6, 2, 2, 1, 7]

나의 코드

function solution(score) {
  const avgScore = score.map((item) => (item[0] + item[1]) / 2);
  const sortedAvgScore = score
    .map((item) => (item[0] + item[1]) / 2)
    .sort((a, b) => b - a);

  let array = [];
  for (let i = 0; i < avgScore.length; i++) {
    array.push(sortedAvgScore.indexOf(avgScore[i]) + 1);
  }

  return array;
}

평균 배열과 평균 배열의 내림차순을 구하고,
내림차순 배열에서 평균 배열 원소들의 index를 반환하였다.

그런데 또 한 줄 짜리 풀이를 발견하였다.
이제 놀랍지도 않다.

function solution(score) {
  return score.map((el) => {
    return (
      score.filter((v) => (v[0] + v[1]) / 2 > (el[0] + el[1]) / 2).length + 1
    );
  });
}

배열 [[80, 70],[90, 50],[40, 70],[50, 80]]이 있다고 가정하자.
맨 처음 el은 [80,70]이 되어 map 적용.
전체 배열에서 80,70의 평균보다 큰 평균을 가진 원소들만 filter하여 새로운 배열을 만든다.
80,70보다 평균이 큰 원소들은 없으므로
score.filter((v) => (v[0] + v[1]) / 2 > (el[0] + el[1]) / 2)
은 []이된다. 빈 배열이므로 length=0이 되고, 전체 1등이라는 의미이므로 +1을 해주면
map을 적용할 때 [80,70]이 등수인 1로 바뀌는 것이다.

그래도 다시 생각해보니 충격적이다.

profile
기록에 진심인 개발자 🌿

0개의 댓글