완전탐색에 해당하는 문제이다.
function solution(answers) {
var answer = [];
const score = [
{ name: 1, count : 0 },
{ name: 2, count : 0 },
{ name: 3, count : 0 },
];
const user1 = [1, 2, 3, 4, 5];
const user2 = [2, 1, 2, 3, 2, 4, 2, 5];
const user3 = [3, 3, 1, 1, 2, 2, 4, 4, 5, 5];
answers.forEach((answer, index) => {
const value = index + 1;
if (value < 5) {
if (answer === user1[index]) score[0].count += 1;
} else {
if (answer === user1[index % 5]) score[0].count += 1;
}
if (value < 8) {
if (answer === user2[index]) score[1].count += 1;
} else {
if (answer === user2[index % 8]) score[1].count += 1;
}
if (value < 10) {
if (answer === user3[index]) score[2].count += 1;
} else {
if (answer === user3[index % 10]) score[2].count += 1;
}
});
score.sort((a,b) => a.count > b.count ? -1 : 1)
answer = score.filter((val) => val.count === score[0].count).map((val) => val.name);
return answer;
}
위와 같이 문제를 해결해보았다.
1. score를 쉽게 정렬하기위해 배열을 이용했다.
2. 수포자들이 찍기 방식이 일정한 패턴을 가지고 있음을 활용한다. (사실, 랜덤이라면 답을 구하는것 자체가 불가능하지않을까?)
3. 각자의 패턴의 길이만큼은 단순비교를
4. 패턴의 길이 이상에서는 나머지 값을 이용해서 답안과 비교한다.
5. forEach를 이용해 답안의 수 만큼 반복한다.
6. 마지막으로 배열을 정렬하고, 가장 큰 수와 같은 수만큼 답안을 획득한 수포자들만 필터한다.
7. map으로 수포자들의 이름(1,2,3)만 뽑아낸다.
간단하지만,
패턴을 이용한다. 나머지를 이용한다. 와 같은 발상을 못한다면
맞출수없는 문제같다.
마지막으로, 완전탐색의 개념을 살짝 짚어본다.
완전 탐색이란? 가능한 모든 경우의 수를 탐색하고, 확인하는 방법입니다.