BruteForce_Lv1_모의고사

Eugenius1st·2022년 8월 12일
0

Programmers_JavaScript

목록 보기
4/30
post-thumbnail

BruteForceLv1모의고사

문제

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

풀이

  • 바보들의 정답 리스트들 만든다
  • for문으로 answers의 길이만큼 정답을 일일히 확인한다
  • 이 때, answers의 인덱스는 바보들의 리스트 길이로 나눠주어 바보돌의 리스트 인덱스를 초과하는 값까지 처리하도록 한다.
  • 마지막으로 가장 최대 점수와 같은 바보들의 점수를 push 한다.

코드

function solution(answers) {
    var answer = [];
    const babo1 = [1, 2, 3, 4, 5]
    const babo2 = [2, 1, 2, 3, 2, 4, 2, 5]
    const babo3 = [3, 3, 1, 1, 2, 2, 4, 4, 5, 5]
    let babo1_score = 0
    let babo2_score = 0
    let babo3_score = 0
    
    for (let i = 0 ; i < answers.length; i++){
      if (babo1[i%babo1.length]===answers[i]) babo1_score += 1
      if (babo2[i%babo2.length]===answers[i]) babo2_score += 1
      if (babo3[i%babo3.length]===answers[i]) babo3_score += 1
    }
  
  const maxScore = Math.max(babo1_score,babo2_score,babo3_score);
  const scoreBoard = [babo1_score,babo2_score,babo3_score]
  for (let i = 0 ; i < scoreBoard.length; i++){
    if(scoreBoard[i] === maxScore) answer.push(i+1) 
  }
    return answer;
}

배운것

function solution(answers) {
    var answer = [];
    var a1 = [1, 2, 3, 4, 5];
    var a2 = [2, 1, 2, 3, 2, 4, 2, 5]
    var a3 = [ 3, 3, 1, 1, 2, 2, 4, 4, 5, 5];

    var a1c = answers.filter((a,i)=> a === a1[i%a1.length]).length;
    var a2c = answers.filter((a,i)=> a === a2[i%a2.length]).length;
    var a3c = answers.filter((a,i)=> a === a3[i%a3.length]).length;
    var max = Math.max(a1c,a2c,a3c);

    if (a1c === max) {answer.push(1)};
    if (a2c === max) {answer.push(2)};
    if (a3c === max) {answer.push(3)};


    return answer;
}
  • filter로 배열의 인덱스에 해당하는 값과 일치하는 것을 새로운 배열에 넣어준다.
  • 가장 긴 길이의 값을 확인해서 push 한다
profile
최강 프론트엔드 개발자가 되고싶은 안유진 입니다

0개의 댓글