프로그래머스 - 성격 유형 검사하기

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

풀이 방법

1. choices의 원소를 인덱스로 가지고 각 원소에 따른 점수를 배열에 저장한다.

2. map 자료형 m을 선언한다.

3-1. 반복문을 돌며 choices[i]가 4보다 작으면 survey[i]의 첫 번째 글자의 value에 점수를 더한다.

3-2. choices[i]가 4보다 크면 survey[i]의 두 번째 글자의 value에 점수를 더한다.

4. 각 지표 번호에 속하는 문자의 value를 비교해서 더 큰 문자를 answer에 더한다.

5. answer 리턴

#include <string>
#include <vector>
#include <map>

using namespace std;

string solution(vector<string> survey, vector<int> choices) {
    string answer = "";
    
    int score[8] = {0, 3, 2, 1, 0, 1, 2, 3};
    map<char, int> m;
    
    for(int i = 0; i < survey.size(); i++){
        if(choices[i] < 4) m[survey[i][0]] += score[choices[i]];
        else if(choices[i] > 4) m[survey[i][1]] += score[choices[i]];
        else continue;
    }
    
    answer += m['R'] >= m['T'] ? "R" : "T";
    answer += m['C'] >= m['F'] ? "C" : "F";
    answer += m['J'] >= m['M'] ? "J" : "M";
    answer += m['A'] >= m['N'] ? "A" : "N";
    
    return answer;
}

 

'프로그래머스 > 1레벨' 카테고리의 다른 글

둘만의 암호/C++  (0) 2023.02.03
신고 결과 받기/C++  (0) 2023.01.03
숫자 짝꿍/C++  (1) 2023.01.03
푸드 파이트 대회/C++  (0) 2023.01.03
가장 가까운 같은 글자/C++  (0) 2023.01.03

+ Recent posts