[프로그래머스] 모의고사

Narcoker·2022년 9월 23일
0

코딩테스트

목록 보기
42/152

문제 설명

수포자는 수학을 포기한 사람의 준말입니다. 수포자 삼인방은 모의고사에 수학 문제를 전부 찍으려 합니다. 수포자는 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하는 값을 오름차순 정렬해주세요.

입출력 예

풀이

완전 탐색을 이용한 풀이이다.
답안지(answers)와 패턴(marking)의 값을 하나씩 비교해서 같으면
count 값을 1 증가시켜 반환하는 함수 grading(marking)을 만들어서
각각 점수를 할당한 후,
이 점수들의 최대값을 구해서 같은 값이면 answer에 수포자의 번호를 push한다.

function solution(answers) {
    let answer = [];
    function grading(marking) {
        let count = 0;
        for (let i = 0; i < answers.length; i++) {
            if (answers[i] === marking[i % marking.length]) count++;
        }
        return count;
    }
    let count1 = grading([1, 2, 3, 4, 5]);
    let count2 = grading([2, 1, 2, 3, 2, 4, 2, 5]);
    let count3 = grading([3, 3, 1, 1, 2, 2, 4, 4, 5, 5]);

    let max = Math.max(count1, count2, count3);
    if (count1 === max) answer.push(1);
    if (count2 === max) answer.push(2);
    if (count3 === max) answer.push(3);

    return answer;
}

회고

나누기 연산을 활용하여 참조하는 방법

profile
열정, 끈기, 집념의 Frontend Developer

0개의 댓글