문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/118666
문제 설명
성격 유형 검사는 다음과 같은 4개 지표로 성격 유형을 구분합니다. 성격은 각 지표에서 두 유형 중 하나로 결정됩니다.
지표 번호 | 성격 유형 |
1번 지표 | 라이언형(R), 튜브형(T) |
2번 지표 | 콘형(C), 프로도형(F) |
3번 지표 | 제이지형(J), 무지형(M) |
4번 지표 | 어피치형(A), 네오형(N) |
4개의 지표가 있으므로 성격 유형은 총 16가지가 나올 수 있습니다.
검사지에는 총 n개의 질문이 있고, 각 질문에는 아래와 같은 7개의 선택지가 있습니다.
- 매우 비동의 | 비동의 | 약간 비동의 | 모르겠음 | 약간 동의 | 동의 | 매우 동의
각 질문은 1가지 지표로 성격 유형 점수를 판단합니다.
예를 들어, "NA" 지표에 대한 질문에서 아래 표처럼 점수를 매길 수 있습니다.
선택지 | 성격 유형 점수 |
매우 비동의 | N(네오형) 3점 |
비동의 | N(네오형) 2점 |
약간 비동의 | N(네오형) 1점 |
모르겠음 | 어떤 성격의 유형도 점수를 얻지 않습니다. |
약간 동의 | A(어치피형) 1점 |
동의 | A(어치피형) 2점 |
매우 동의 | A(어치피형) 3점 |
각 선택지는 고정적인 크기의 점수를 가지고 있습니다.
- 매우 동의 나 매우 비동의 선택지를 선택하면 3점을 얻습니다.
- 동의 나 비동의 선택지를 선택하면 2점을 얻습니다.
- 약간 동의 나 약간 비동의 선택지를 선택하면 1점을 얻습니다.
- 모르겠음 선택지를 선택하면 점수를 얻지 않습니다.
검사 결과는 모든 질문의 성격 유형 점수를 더하여 각 지표에서 더 높은 점수를 받은 성격 유형이 검사자의 성격 유형이라고 판단합니다. 단, 하나의 지표에서 각 성격 유형 점수가 같으면, 두성격 유형 중 사전 순으로 빠른 성격 유형을 검사자의 성격 유형이라고 판단합니다.
질문마다 판단하는 지표를 담은 1차원 문자열 배열 survey와 검사자가 각 질문마다 선택한 선택지를 담은 1차원 정수 배열 choices가 매개변수로 주어집니다. 이때, 검사자의 성격 유형 검사 결과를 지표 번호 순서대로 리턴하도록 함수를 완성하세요.
제한 사항
- 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 | 매우 동의 |
✅ Code - 성공
function solution(survey, choices) {
var answer = '';
const personality = ['R', 'T', 'C', 'F', 'J', 'M', 'A', 'N']; // 성격 유형
const personality_score = [0, 0, 0, 0, 0, 0, 0, 0]; // 유형 별 점수
const score = [3, 2, 1, 0, 1, 2, 3]; // 질문에 따른 점수 배치
for (let i = 0; i < survey.length; i++) {
const [sur1, sur2] = survey[i].split('');
let idx = 0;
if (choices[i] >= 5) idx = personality.indexOf(sur2); // 5 이상(약간 동의)부터 다음 유형에 점수를 줘야하므로 조건 처리
else idx = personality.indexOf(sur1);
personality_score[idx] += score[choices[i] - 1];
}
for (let i = 0; i < personality_score.length; i += 2) {
if (personality_score[i] >= personality_score[i + 1]) answer += personality[i];
else answer += personality[i + 1];
}
return answer;
}
'알고리즘 문제 > 프로그래머스_Lv1 도장깨기' 카테고리의 다른 글
[프로그래머스] 숫자 짝꿍 (Javascript) (0) | 2025.01.07 |
---|---|
[프로그래머스] 신고 결과 받기 (Javascript) (1) | 2025.01.03 |
[프로그래머스] 나머지가 1이 되는 수 찾기 (Javascript) (0) | 2025.01.02 |
[프로그래머스] 최소직사각형 (Javascript) (0) | 2025.01.01 |
[프로그래머스] 없는 숫자 더하기 (Javascript) (0) | 2024.12.31 |