gimmickbutreal
[프로그래머스/자바] 성격 유형 테스트 - Switch 본문
문제 설명
나만의 카카오 성격 유형 검사지를 만들려고 합니다.
성격 유형 검사는 다음과 같은 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
- choices의 길이 = survey의 길이
• choices | • 뜻 |
• 1 | • 매우 비동의 |
• 2 | • 비동의 |
• 3 | • 약간 비동의 |
• 4 | • 모르겠음 |
• 5 | • 약간 동의 |
• 6 | • 동의 |
• 7 | • 매우 동의 |
풀이과정
1. 처음에는 Map, Queue등을 사용하려고 하다가 부등호만으로도 해결이 가능함을 깨달음
2. 음수와 양수로 구분하여, 두 알파벳 중 무엇을 선택하는지 정함
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
import java.util.*;
class Solution {
public String solution(String[] survey, int[] choices) {
int scoreRT=0, scoreCF=0, scoreJM=0, scoreAN=0;
String r1 = "", r2 = "", r3 = "", r4 ="";
for (int i =0; i<survey.length; i++){
int score = 0;
switch(choices[i]){
case 1:
score = -3;
break;
case 2:
score = -2;
break;
case 3:
score = -1;
break;
case 4:
break;
case 5:
score = 1;
break;
case 6:
score = 2;
break;
case 7:
score = 3;
break;
default:
break;
}
switch(survey[i]){
case "RT":
scoreRT += score;
break;
case "TR":
scoreRT -= score;
break;
case "CF":
scoreCF += score;
break;
case "FC":
scoreCF -= score;
break;
case "JM":
scoreJM += score;
break;
case "MJ":
scoreJM -= score;
break;
case "AN":
scoreAN += score;
break;
case "NA":
scoreAN -= score;
break;
}
}
if (scoreRT>0){
r1 = "T";
} else r1 = "R";
if (scoreCF>0){
r2 = "F";
} else r2 = "C";
if (scoreJM>0){
r3 = "M";
} else r3 = "J";
if (scoreAN>0){
r4 = "N";
} else r4 = "A";
return r1+r2+r3+r4;
}
}
|
cs |

'Algorithm > Java' 카테고리의 다른 글
[프로그래머스/자바] 로또의 최고 순위와 최저 순위 - Switch (0) | 2023.07.15 |
---|---|
[프로그래머스/자바] 공원 산책 - switch (0) | 2023.07.13 |
[프로그래머스/자바] 햄버거 만들기 - append (0) | 2023.07.11 |
[프로그래머스/자바] 신규 아이디 추천 - 정규표현식 (0) | 2023.07.10 |
[프로그래머스/자바] 키패드 누르기 - 맨해튼 방식 (0) | 2023.07.08 |