[Python] 성격 유형 검사하기 (쉬움)
문제
나만의 카카오 성격 유형 검사지를 만들려고 합니다.
성격 유형 검사는 다음과 같은 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 매우 동의
입출력 예
survey | choices | result |
["AN", "CF", "MJ", "RT", "NA"] | [5, 3, 2, 7, 5] | "TCMA" |
["TR", "RT", "TR"] | [7, 1, 3] | "RCJA" |
풀이
survey에 따른 choices를 바탕으로 각 성격 유형에 점수를 더한 후,
이를 바탕으로 성격 결과를 판단하는 간단한 문제였다.
'''
더 높은 점수를 받은 게 성격 유형(지표)
점수가 같으면 사전 순으로 빠른 거
survey: 질문이 판단하는 지표 (XY. 비동의시 X, 동의시 Y)
choices: 선택
[1- 매우 비동의(+3), 2-비동의(+2), 3-약간 비동의(+1), 4, 5-약간 동의(+1), 6-동의(+2), 7-매우 동의(+3)]
검사자의 결과를 지표 번호 순서대로 입력
'''
def solution(survey, choices):
answer = ''
type = ['R', 'T', 'C', 'F', 'J', 'M', 'A', 'N']
score = {x:0 for x in type}
#print(score) #{'R': 0, 'T': 0, 'C': 0, 'F': 0, 'J': 0, 'M': 0, 'A': 0, 'N': 0}
for i in range(len(survey)):
X, Y = survey[i][0], survey[i][1]
#print(X, Y)
if choices[i] < 4: # 비동의 (X)
score[X] += 4-choices[i]
else: # 동의(Y)
score[Y] += choices[i]-4
if score['R'] < score['T']:
answer += 'T'
else:
answer +='R'
if score['C'] < score['F']:
answer += 'F'
else:
answer +='C'
if score['J'] < score['M']:
answer +='M'
else:
answer +='J'
if score['A'] < score['N']:
answer +='N'
else:
answer +='A'
return answer
다른 풀이
위 풀이에서 dict를 사용해서 각 성격유형 별로 점수를 계산했다면 list를 사용할 수도 있다
그리고 점수를 계산할 때 위 문제처럼 정확한 점수를 얻을 필요 없이 {'R': 0, 'T': 3, 'C': 1, 'F': 0, 'J': 0, 'M': 2, 'A': 1, 'N': 1}
두 성격 유형 중 뭐가 높은 지만 판단하면 되므로 survey의 두번째 성격 유형에 대해 choices[i]-4 점수를 더해준다.
choices[i] 점수가 5 이상이라면 원래 대로 계산될 것이고, 4 미만이라면 음수 값이 들어가므로 survey 첫번째 성격 유형의 점수가 0으로 높게 반영된다.
def solution(survey, choices):
answer = ''
RTCFJMAN = [0,0,0,0,0,0,0,0]
str = "RTCFJMAN"
for i in range(len(survey)):
RTCFJMAN[str.index(survey[i][1])] += choices[i]-4
#print(RTCFJMAN) # 테케1에서 [0, 3, 0, -1, -2, 0, 1, 1]
if(RTCFJMAN[0]>=RTCFJMAN[1]): answer+= "R"
else: answer+="T"
if(RTCFJMAN[2]>=RTCFJMAN[3]): answer+= "C"
else: answer+="F"
if(RTCFJMAN[4]>=RTCFJMAN[5]): answer+= "J"
else: answer+="M"
if(RTCFJMAN[6]>=RTCFJMAN[7]): answer+= "A"
else: answer+="N"
return answer
반대로 survey의 첫번째 성격 유형의 점수를 쓰고 싶다면
N[str.index(survey[i][0])] += 4- choices[i]