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