- 성격 유형 검사하기2023년 12월 17일 22시 00분 31초에 업로드 된 글입니다.작성자: oneseel
성격 유형 검사하기
문제설명
나만의 카카오 성격 유형 검사지를 만들려고 합니다.
성격 유형 검사는 다음과 같은 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 함수를 완성해주세요.
제한사항
- 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
입출력 예
입출력 예 설명
입출력 예 #1
AN지표에서 5점은 N += 1, CF지표에서 3점은 C += 1
MJ지표에서 2점은 M += 2, RT지표에서 7점은 T += 3, NA지표에서 5점은 A += 1
따라서 TCMA이다.
내 풀이
>> survey 배열에서 아래와 같은 값일 때, 각 check메서드를 통해 character배열에 값을 넣는다.
>> check메서드는 choice배열에 있는 값일 때, 각 점수를 넣어준다.
>> character 배열에서 크기를 비교하여 해당하는 값을 StringBuilder 객체에 넣는다.
class Solution { public String solution(String[] survey, int[] choices) { int[] character = new int[8]; // 각 성격지표 배열 // R, T, C, F, J, M, A, N for (int i = 0; i < survey.length; i++) { if (survey[i].equals("RT")) rCheck(choices, character, i); else if (survey[i].equals("TR")) tCheck(choices, character, i); else if (survey[i].equals("CF")) cCheck(choices, character, i); else if (survey[i].equals("FC")) fCheck(choices, character, i); else if (survey[i].equals("JM")) jCheck(choices, character, i); else if (survey[i].equals("MJ")) mCheck(choices, character, i); else if (survey[i].equals("AN")) aCheck(choices, character, i); else if (survey[i].equals("NA")) nCheck(choices, character, i); } StringBuilder sb = new StringBuilder(); sb.append(character[0] >= character[1] ? "R" : "T"); sb.append(character[2] >= character[3] ? "C" : "F"); sb.append(character[4] >= character[5] ? "J" : "M"); sb.append(character[6] >= character[7] ? "A" : "N"); return sb.toString(); } private void updateCharacter(int[] choices, int[] character, int i, int idx1, int idx2) { if (choices[i] == 1) character[idx1] += 3; else if (choices[i] == 2) character[idx1] += 2; else if (choices[i] == 3) character[idx1] += 1; else if (choices[i] == 4) character[idx1] += 0; else if (choices[i] == 5) character[idx2] += 1; else if (choices[i] == 6) character[idx2] += 2; else if (choices[i] == 7) character[idx2] += 3; } private void rCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 0, 1); } private void tCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 1, 0); } private void cCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 2, 3); } private void fCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 3, 2); } private void jCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 4, 5); } private void mCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 5, 4); } private void aCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 6, 7); } private void nCheck(int[] choices, int[] character, int i) { updateCharacter(choices, character, i, 7, 6); } }
https://school.programmers.co.kr/learn/courses/30/lessons/118666
'코딩테스트' 카테고리의 다른 글
햄버거 만들기 (0) 2023.12.15 로또의 최고 순위와 최저 순위 (0) 2023.12.01 삼총사 (1) 2023.11.26 이상한 문자 만들기 (0) 2023.11.24 3진법 뒤집기 (0) 2023.11.24 댓글