Programmers | 성격 유형 검사하기 (2022 KAKAO TECH INTERNSHIP)

HN·2023년 11월 9일
0

프로그래머스

목록 보기
28/30
post-custom-banner

성격 유형 검사하기

❔문제설명

나만의 카카오 성격 유형 검사지를 만들려고 합니다.
성격 유형 검사는 다음과 같은 4개 지표로 성격 유형을 구분합니다. 성격은 각 지표에서 두 유형 중 하나로 결정됩니다.

<지표 번호 성격 유형>

  • 1번 지표 | 라이언형(R), 튜브형(T)
  • 2번 지표 | 콘형(C), 프로도형(F)
  • 3번 지표 | 제이지형(J), 무지형(M)
  • 4번 지표 | 어피치형(A), 네오형(N)

4개의 지표가 있으므로 성격 유형은 총 16(=2 x 2 x 2 x 2)가지가 나올 수 있습니다. 예를 들어, "RFMN"이나 "TCMA"와 같은 성격 유형이 있습니다.

검사지에는 총 n개의 질문이 있고, 각 질문에는 아래와 같은 7개의 선택지가 있습니다.

매우 비동의
비동의
약간 비동의
모르겠음
약간 동의
동의
매우 동의

각 질문은 1가지 지표로 성격 유형 점수를 판단합니다.

예를 들어, 어떤 한 질문에서 4번 지표로 아래 표처럼 점수를 매길 수 있습니다.

<선택지 성격 유형 점수>

  • 매우 비동의 네오형 3점
  • 비동의 네오형 2점
  • 약간 비동의 네오형 1점
  • 모르겠음 어떤 성격 유형도 점수를 얻지 않습니다
  • 약간 동의 어피치형 1점
  • 동의 어피치형 2점
  • 매우 동의 어피치형 3점

이때 검사자가 질문에서 약간 동의 선택지를 선택할 경우 어피치형(A) 성격 유형 1점을 받게 됩니다. 만약 검사자가 매우 비동의 선택지를 선택할 경우 네오형(N) 성격 유형 3점을 받게 됩니다.

위 예시처럼 네오형이 비동의, 어피치형이 동의인 경우만 주어지지 않고, 질문에 따라 네오형이 동의, 어피치형이 비동의인 경우도 주어질 수 있습니다.
하지만 각 선택지는 고정적인 크기의 점수를 가지고 있습니다.

  • 매우 동의매우 비동의 선택지를 선택하면 3점을 얻습니다.
  • 동의비동의 선택지를 선택하면 2점을 얻습니다.
  • 약간 동의약간 비동의 선택지를 선택하면 1점을 얻습니다.
  • 모르겠음 선택지를 선택하면 점수를 얻지 않습니다.

검사 결과는 모든 질문의 성격 유형 점수를 더하여 각 지표에서 더 높은 점수를 받은 성격 유형이 검사자의 성격 유형이라고 판단합니다. 단, 하나의 지표에서 각 성격 유형 점수가 같으면, 두 성격 유형 중 사전 순으로 빠른 성격 유형을 검사자의 성격 유형이라고 판단합니다.

질문마다 판단하는 지표를 담은 1차원 문자열 배열 survey와 검사자가 각 질문마다 선택한 선택지를 담은 1차원 정수 배열 choices가 매개변수로 주어집니다. 이때, 검사자의 성격 유형 검사 결과를 지표 번호 순서대로 return 하도록 solution 함수를 완성해주세요.

제한사항

  • 1 ≤ survey의 길이 ( = n) ≤ 1,000
    + survey의 원소는 "RT", "TR", "FC", "CF", "MJ", "JM", "AN", "NA" 중 하나입니다.
    + survey[i]의 첫 번째 캐릭터는 i+1번 질문의 비동의 관련 선택지를 선택하면 받는 성격 유형을 의미합니다.
    + survey[i]의 두 번째 캐릭터는 i+1번 질문의 동의 관련 선택지를 선택하면 받는 성격 유형을 의미합니다.
  • choices의 길이 = survey의 길이
    + choices[i]는 검사자가 선택한 i+1번째 질문의 선택지를 의미합니다.
    + 1 ≤ choices의 원소 ≤ 7

<choices 뜻>

  • 1 매우 비동의
  • 2 비동의
  • 3 약간 비동의
  • 4 모르겠음
  • 5 약간 동의
  • 6 동의
  • 7 매우 동의





풀이

ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ
풀기는 했는데 보다시피 if문의 행렬이라서 엄청 지저분함.

function solution(survey, choices) {
    var answer = '';
    let category = {
        R: 0,
        T: 0,
        F: 0,
        C: 0,
        M: 0,
        J: 0,
        A: 0,
        N: 0
    }
    
    for(let i = 0; i < choices.length; i++) {
        if(choices[i] == 4) {
            continue
        } else if(choices[i] < 4) {
            category[survey[i][0]] += 4 - choices[i]
        } else if(choices[i] > 4) {
            category[survey[i][1]] += choices[i] - 4
        }
    }
    
    if(category.R < category.T) {
        answer += "T"
    } else if(category.R > category.T) {
        answer += "R"
    } else {
        answer += ["R", "T"].sort()[0]
    }
    
    if(category.C < category.F) {
        answer += "F"
    } else if(category.C > category.F) {
        answer += "C"
    } else {
        answer += ["C", "F"].sort()[0]
    }
    
    if(category.J < category.M) {
        answer += "M"
    } else if(category.J > category.M) {
        answer += "J"
    } else {
        answer += ["J", "M"].sort()[0]
    }
    
    if(category.A < category.N) {
        answer += "N"
    } else if(category.A > category.N) {
        answer += "A"
    } else {
        answer += ["A", "N"].sort()[0]
    }
    
    return answer;
}


그래서 생각해본 또 다른 방법.
choices의 값이 4일 때는 굳이 체크해주지 않아도 됐다. 또, 이미 유형이 알파벳 오름차순으로 되어있기 때문에 sort()를 사용해줄 필요가 없다고 생각했음.
그리고 for문, if문을 다 삼항연산자로 바꾸니까 좀 더 간결해지긴 했는데 그래도 썩.. 깔끔해보이진 않는다😅 어렵다 어려워😫

function solution(survey, choices) {
    var answer = '';
    let category = {
        R: 0,
        T: 0,
        F: 0,
        C: 0,
        M: 0,
        J: 0,
        A: 0,
        N: 0
    }
    
    choices.forEach((choice, idx) => {
        choice < 4 ? category[survey[idx][0]] += 4 - choice : category[survey[idx][1]] += choice - 4
        
    })
    
    answer += category.R >= category.T ? "R" : "T"
    answer += category.C >= category.F ? "C" : "F"
    answer += category.J >= category.M ? "J" : "M"
    answer += category.A >= category.N ? "A" : "N"
    
    return answer;
}










✔출처:프로그래머스

post-custom-banner

0개의 댓글