문제
나만의 카카오 성격 유형 검사지를 만들려고 합니다. 성격 유형 검사는 다음과 같은 4개 지표로 성격 유형을 구분합니다. 성격은 각 지표에서 두 유형 중 하나로 결정됩니다.지표 번호 | 성격 유형 |
1번 지표 | 라이언형(R), 튜브형(T) |
2번 지표 | 콘형(C), 프로도형(F) |
3번 지표 | 제이지형(J), 무지형(M) |
4번 지표 | 어피치형(A), 네오형(N) |
검사지에는 총 n개의 질문이 있고, 각 질문에는 아래와 같은 7개의 선택지가 있습니다.
매우 비동의 비동의 약간 비동의   모르겠음 약간 동의 동의   매우 동의
각 질문은 1가지 지표로 성격 유형 점수를 판단합니다.
예를 들어, 어떤 한 질문에서 4번 지표로 아래 표처럼 점수를 매길 수 있습니다.
선택지 | 성격 유형 점수 |
매우 비동의 | 네오형 3점 |
비동의 | 네오형 2점 |
약간 비동의 | 네오형 1점 |
모르겠음 | 어떤 성격 유형도 점수를 얻지 않습니다 |
매우 동의 | 어피치형 1점 |
동의 | 어피치형 2점 |
약간 동의 | 어피치형 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" |
C#
지문이 길다고 겁먹지 말고, 차근 차근 문제를 해결하는 것이 중요함.!! 문제만 잘 분석하니 풀이는 생각보다 어렵지 않았음
기본 틀
- 지문 : 유형 + 유형 → 비동의 + 동의 → 비동의면 앞 유형에, 동의면 뒤 유형에 점수 추가
- 매우 동의하지 않음 ~> 매우 동의함 순서로 숫자가 1개씩 증가함.
구현
- 타입 별로 점수 증가하는 게 가장 중요한 로직이니 여기서 시간이 많이 소요되지 않도록 Dictionary를 사용하여, 바로 바로 타입을 찾아 점수를 증가하도록 함.
- string 보다는 enum이 타이별로 변환이 자유로워서 타입을 enum으로 설정함. → dictionary 초기화 할 때는 정수형 타입을 사용하고, 인덱스 검색이나 값 출력에는 string로 씀
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
using System;
using System.Text;
using System.Collections.Generic;
public class Solution
{
public string solution(string[] survey, int[] choices)
{
Dictionary<PerstyType, int> dicAnswer = GetPersonalityType();
for(int i = 0; i < survey.Length; i++)
{
if (choices[i] < 4) //비동의
{
dicAnswer[ToPerstyType(survey[i].Substring(0, 1))] += (4 - choices[i]);
}
else if (choices[i] > 4) //동의
{
dicAnswer[ToPerstyType(survey[i].Substring(1, 1))] += (choices[i] - 4);
}
}
StringBuilder sboType = new StringBuilder();
for(int i=0; i<8; )
{
PerstyType type1 = (PerstyType)i++;
PerstyType type2 = (PerstyType)i++;
sboType.Append(dicAnswer[type1] >= dicAnswer[type2] ? type1 : type2);
}
return sboType.ToString();
}
private Dictionary<PerstyType, int> GetPersonalityType()
{
Dictionary<PerstyType, int> dic = new Dictionary<PerstyType, int>();
for(int i = 0; i < 8; i++)
{
dic.Add((PerstyType)i, 0);
}
return dic;
}
private PerstyType ToPerstyType(string str)
{
return (PerstyType)Enum.Parse(typeof(PerstyType), str);
}
enum PerstyType
{
R, //라이언형
T, //튜브형
C, //콘형
F, //프로도형
J, //제이지형
M, //무지형
A, //어피치형
N //네오형
};
}
[성공]
프로그래머스에서 문제 확인