나만의 카카오 성격 유형 검사지를 만들려고 합니다.
성격 유형 검사는 다음과 같은 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 함수를 완성해주세요.
survey | choices | result |
---|---|---|
["AN", "CF", "MJ", "RT", "NA"] | [5, 3, 2, 7, 5] | "TCMA" |
["TR", "RT", "TR"] | [7, 1, 3] | "RCJA" |
function solution(survey, choices) {
const types = { R: 0, T: 0, C: 0, F: 0, J: 0, M: 0, A: 0, N: 0 };
let answer = "";
//1. cholces에 따라 point를 누적한다.
for(let i = 0 ; i < choices.length ; i++){
//servey의 각 요소를 split해 구조분해할당으로 받아온다.
const [leftType, rightType] = survey[i].split("");
//점수를 절대값으로 저장한다.
const point = Math.abs(choices[i] - 4);
if(choices[i] < 4){
types[leftType] += point;
} else if(choices[i] > 4) {
types[rightType] += point;
}
}
//2. 쌓인 포인트를 가지고 성격 유형을 산출한다. (이때 동일값이라면 내림차순 기준)
//key값들만 따로 모은다.
const type = Object.keys(types);
//+1이 아닌 +2를 하는 이유 -> 2개가 한쌍이기 때문에 한 타입에 대해 검증하면 +2를 해 다음 타입을 검증할 수 있다.
for(let i = 0; i < type.length ; i +=2){
const typeOne = types[type[i]];
const typeTwo = types[type[i+1]];
if(typeOne >= typeTwo){
answer += type[i]; //같거나 크다면 첫번째 타입
} else{
answer += type[i+1]; //작다면 두번째 타입 요소
}
}
return answer;
}
/*
점수체계 :
1 또는 7 -> 3점
2 또는 6 -> 2점
3 또는 5 -> 1점
4 -> 0점
! 여기서 알수 있는 점
그럼 choices[i]에서 -4를 했을 때 음수면 앞에꺼 양수면 뒤에꺼
점수는 choices[i]-4 한 값의 절대값이 된다. Math.abs(choices[i] - 4)
*/
function solution(survey, choices) {
const MBTI = {};
const types = ["RT","CF","JM","AN"];
// 일일이 지정해서 객체를 만든게 아니라 자동으로 객체를 만드셨다.
types.forEach((type) =>
type.split('').forEach((char) => MBTI[char] = 0)
)
//
choices.forEach((choice, index) => {
// 이렇게 해도 하나의 문자열이 나눠지는구나!
const [disagree, agree] = survey[index];
// chice의 값에 따라 성향을 나눠, 위에서 만든 MBTI 객체의 key값에 넣어준다
// 점수 환산 로직에 맞춰서 산술한 값을 누적합 한다.
MBTI[choice > 4 ? agree : disagree] += Math.abs(choice - 4);
});
// map에서도 이런 방식으로 하나의 문자열을 a, b로 나눌 수 있구나..!
return types.map(([a, b]) => MBTI[b] > MBTI[a] ? b : a).join("");