문제 설명

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

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

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

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

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

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


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

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

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

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

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


내가 푼 풀이

각 성격유형들을 Dictionary에 저장하고, 주어진 choies를 순회하며 성격유형 점수를 올린다.

지표 순으로 점수가 높은 성격유형을 차례대로 출력한다.

 

import Foundation

func solution(_ survey:[String], _ choices:[Int]) -> String {
    var checkList = ["RT", "CF", "JM", "AN"]    //지표 순서로 저장된 배열
    var dict = ["R": 0, "T": 0, "C": 0, "F": 0, "J": 0, "M": 0, "A": 0, "N": 0] // 성격유형 점수들
    var points = [0, 3, 2, 1, 0, 1, 2, 3]   // 입력된 값에 따른 점수
    var resultStr = ""
    
    for i in 0..<survey.count {
        var arr = survey[i].map{String($0)}
        var str = ""
        var point = points[choices[i]]
        
        if choices[i] == 4 {    // 4 항목은 점수변동 없음 -> 스킵
            continue
        }
        if choices[i] > 4 {     // 항목 점수대로 검사
            str = arr[1]
        } else {
            str = arr[0]
        }
        dict[str]! += point // 점수 추가
    }
    
    for i in 0..<checkList.count {  // 지표 순서대로 순회하며 점수 높은유형 출력
        var str = checkList[i].map{String($0)}
        if dict[str[0]]! < dict[str[1]]! {
            resultStr += "\(str[1])"
        } else if dict[str[0]]! > dict[str[1]]! {
            resultStr += "\(str[0])"
        } else {
            str.sort{$0 < $1}   // 점수가 같으면 사전순으로
            resultStr += "\(str[0])"
        }
    }
    
    return resultStr
}

'코딩테스트 > 프로그래머스' 카테고리의 다른 글

나머지가 1이 되는 수 찾기 Swift  (0) 2023.04.10
신고 결과 받기 Swift  (0) 2023.04.10
숫자 짝궁 Swift  (0) 2023.04.10
삼총사 Swift  (0) 2023.04.10
콜라 문제 Swift  (0) 2023.04.10

+ Recent posts