[코딩테스트/JS] 모의고사 (feat. 파이프 없이 못사는 개발자)

ScriptKid·2021년 3월 30일
0

코딩테스트

목록 보기
11/16
post-thumbnail

모의고사

문제 설명

수포자는 수학을 포기한 사람의 준말입니다. 수포자 삼인방은 모의고사에 수학 문제를 전부 찍으려 합니다. 수포자는 1번 문제부터 마지막 문제까지 다음과 같이 찍습니다.

1번 수포자가 찍는 방식: 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, ...
2번 수포자가 찍는 방식: 2, 1, 2, 3, 2, 4, 2, 5, 2, 1, 2, 3, 2, 4, 2, 5, ...
3번 수포자가 찍는 방식: 3, 3, 1, 1, 2, 2, 4, 4, 5, 5, 3, 3, 1, 1, 2, 2, 4, 4, 5, 5, ...

1번 문제부터 마지막 문제까지의 정답이 순서대로 들은 배열 answers가 주어졌을 때, 가장 많은 문제를 맞힌 사람이 누구인지 배열에 담아 return 하도록 solution 함수를 작성해주세요.

제한 조건

  • 시험은 최대 10,000 문제로 구성되어있습니다.
  • 문제의 정답은 1, 2, 3, 4, 5중 하나입니다.
  • 가장 높은 점수를 받은 사람이 여럿일 경우, return하는 값을 오름차순 정렬해주세요.

입출력 예

answersreturn
[1,2,3,4,5][1]
[1,3,2,4,2][1,2,3]

입출력 예 설명

입출력 예 #1

수포자 1은 모든 문제를 맞혔습니다.
수포자 2는 모든 문제를 틀렸습니다.
수포자 3은 모든 문제를 틀렸습니다.
따라서 가장 문제를 많이 맞힌 사람은 수포자 1입니다.

입출력 예 #2

모든 사람이 2문제씩을 맞췄습니다.

내 솔루션

  • 단계별로 천천히 따라감.
function solution(answers) {
  const supo1 = [1,2,3,4,5];
  const supo2 = [2,1,2,3,2,4,2,5];
  const supo3 = [3,3,1,1,2,2,4,4,5,5];
  
  return answers.map((answer, idx) =>{
    // 맞춘 녀석들만 모음.
    return [
      supo1[idx % supo1.length] === answer ? 1 : '',
      supo2[idx % supo2.length] === answer ? 2 : '',
      supo3[idx % supo3.length] === answer ? 3 : '',
    ]
    // 2차원 배열이니까 풀고, ''들어간거 제거
  }).flat(Infinity).filter(el=>el).reduce((acc, cur)=>{
    // 정답을 맞춘 수포자에게 포인트를 줌.
    // 위치별로 [1번 수포자, 2번 수포자, 3번 수포자]
    acc[cur-1]++;
    return acc;
  }, [0,0,0]).reduce((acc, cur, idx, arr)=>{
    // 거기서 가장 큰 값을 구하고 Max 값을 가지고 있는 수포자만 따로 뺌.
    let max = Math.max(...arr);
    cur === max ? acc.push(idx+1) : '';
    return acc;
  },[]);
}

감상평

역시 나는 파이프에 미쳐있다. 자제 해야할텐데.. 이젠 파이프가 없으면 살 수 없는 지경

profile
탐함하는 개발자

0개의 댓글