1. 문제
나만의 카카오 성격 유형 검사지를 만들려고 합니다.
성격 유형 검사는 다음과 같은 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가지 지표로 성격 유형 점수를 판단합니다.
매우 비동의 | 네오형 3점 |
비동의 | 네오형 2점 |
약간 비동의 | 네오형 1점 |
모르겠음 | 어떤 성격 유형도 점수를 얻지 않습니다 |
약간 동의 | 어피치형 1점 |
동의 | 어피치형 2점 |
매우 동의 | 어피치형 3점 |
이때 검사자가 질문에서 약간 동의 선택지를 선택할 경우 어피치형(A) 성격 유형 1점을 받게 됩니다. 만약 검사자가 매우 비동의 선택지를 선택할 경우 네오형(N) 성격 유형 3점을 받게 됩니다.
위 예시처럼 네오형이 비동의, 어피치형이 동의인 경우만 주어지지 않고, 질문에 따라 네오형이 동의, 어피치형이 비동의인 경우도 주어질 수 있습니다.
하지만 각 선택지는 고정적인 크기의 점수를 가지고 있습니다.
- 매우 동의나 매우 비동의 선택지를 선택하면 3점을 얻습니다.
- 동의나 비동의 선택지를 선택하면 2점을 얻습니다.
- 약간 동의나 약간 비동의 선택지를 선택하면 1점을 얻습니다.
- 모르겠음 선택지를 선택하면 점수를 얻지 않습니다.
검사 결과는 모든 질문의 성격 유형 점수를 더하여 각 지표에서 더 높은 점수를 받은 성격 유형이 검사자의 성격 유형이라고 판단합니다. 단, 하나의 지표에서 각 성격 유형 점수가 같으면, 두 성격 유형 중 사전 순으로 빠른 성격 유형을 검사자의 성격 유형이라고 판단합니다.
질문마다 판단하는 지표를 담은 1차원 문자열 배열 survey와 검사자가 각 질문마다 선택한 선택지를 담은 1차원 정수 배열 choices가 매개변수로 주어집니다. 이때, 검사자의 성격 유형 검사 결과를 지표 번호 순서대로 return 하도록 solution 함수를 완성해주세요.
2. 풀이
function solution(survey, choices) {
var answer = [];
let all = [{R:0, T:0},{C:0,F:0},{J:0,M:0},{A:0,N:0}]
let 지표 = 0;
let calc = (지표, cateA, cateB, choice)=>{ //파라미터를 받아서 해당 카테고리에 점수를 더해주는 함수
if(choice>4){
all[지표][cateB] += (choice - 4);
}
else if(choice < 4){
all[지표][cateA] += (4 - choice)
}
}
for(i in survey){ //객체 순회
if(survey[i].includes("R")){지표 = 0} //R이 포함된 경우 지표0
else if(survey[i].includes("C")){지표 = 1} //C가 포함된 경우 지표1
else if(survey[i].includes("J")){지표 = 2} //J가 포함된 경우 지표2
else{지표 = 3} //나머지 지표0
calc(지표, survey[i][0], survey[i][1], choices[i]);
}
for(j in all){ //더 높은 항목을 answer배열에 push하는 반복문
if(Object.values(all[j])[0] >= Object.values(all[j])[1]){
answer.push(Object.keys(all[j])[0])
}
else{
answer.push(Object.keys(all[j])[1])
}
}
answer = answer.join('') // answer 배열을 연결해서 합쳐준다.
return answer;
}
3. 알아야할 사항
1) for(i in 객체){}
'ComputerScience > 알고리즘, 프로그래머스' 카테고리의 다른 글
[Lv.1] 신고 결과 받기(카카오 신입/인턴 코딩테스트) (0) | 2023.02.06 |
---|---|
[Lv.1] 둘만의 암호 (정규식과 변수, 복잡한 재반복 for문) (0) | 2023.02.06 |
[Lv.1] 문자열 나누기 (0) | 2023.02.05 |
[Lv.1] 크레인 인형뽑기 게임 (카카오 인턴 코딩테스트, 예외처리 실수) (0) | 2023.02.03 |
[Lv.1] 키패드 누르기(카카오 인턴 코딩테스트, 맨해튼 거리) (0) | 2023.02.03 |
댓글