수포자는 수학을 포기한 사람의 준말입니다. 수포자 삼인방은 모의고사에 수학 문제를 전부 찍으려 합니다. 수포자는 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 함수를 작성해주세요.
answers | return |
---|---|
[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;
},[]);
}
역시 나는 파이프에 미쳐있다. 자제 해야할텐데.. 이젠 파이프가 없으면 살 수 없는 지경