티스토리 뷰

https://school.programmers.co.kr/learn/courses/30/lessons/42840

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 


 

for문

function solution(answers) {
    const answer = []
    const supo = [
        [1, 2, 3, 4, 5], // 1번 수포자의 답
        [2, 1, 2, 3, 2, 4, 2, 5], // 2번 수포자의 답
        [3, 3, 1, 1, 2, 2, 4, 4, 5, 5], // 3번 수포자의 답
    ]
    let one = 0 // 1번 수포자의 점수
    let two = 0 // 2번 수포자의 점수
    let three = 0 // 3번 수포자의 점수

    for(let i = 0; i < answers.length; i++) {
        if(supo[0][i % 5] === answers[i]) one++
        if(supo[1][i % 8] === answers[i]) two++
        if(supo[2][i % 10] === answers[i]) three++
    }

    const max = Math.max(one, two, three)
    if(one === max) answer.push(1)
    if(two === max) answer.push(2)
    if(three === max) answer.push(3)

    return answer
}
  1. 수포자 3명의 답을 배열에 각각 담음
  2. 3명의 점수를 담을 변수 one, tow, three를 만듦
  3. answers 배열의 길이만큼 반복문
    1. 주어진 정답과 일치되는 경우 해당되는 수포자의 점수 +1
      (n개의 답을 반복하므로 i를 n으로 나눈 나머지 값(i % n)을 인덱스로 사용)
  4. 3개 점수들의 최대값을 구함
  5. 최대값과 일치하는 점수를 받은 수포자의 번호를 answer 배열에 담아 return

댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
TAG
more
«   2025/06   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30
글 보관함