알고리즘
프로그래머스 성격 유형 검사하기 (JAVA)
박카스마시며코딩
2023. 8. 3. 19:47
https://school.programmers.co.kr/learn/courses/30/lessons/118666
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
저는 구현을 통해 문제를 해결하였습니다.
저는 map을 통해 각각의 점수를 저장하였고, 각각의 지표의 점수를 보면서 결과값을 만들어 문제를 해결하였습니다.
import java.util.*;
class Solution {
private static final int HALF_SCORE = 4;
private static final char[][] CHARACTER = {{'R','T'},
{'C','F'},
{'J','M'},
{'A','N'}};
public String solution(String[] survey, int[] choices) {
String answer = "";
Map<Character,Integer> sumScore = new HashMap<>();
for(int i = 0 ; i < survey.length ; i++){
String s = survey[i];
int score = choices[i];
char a = s.charAt(0);
char b = s.charAt(1);
if(score < HALF_SCORE){
sumScore.merge(a,Math.abs(score - HALF_SCORE), (v1,v2)->{
return v1 + Math.abs(score - HALF_SCORE);
});
}
if(score > HALF_SCORE){
sumScore.merge(b,Math.abs(score - HALF_SCORE), (v1,v2)->{
return v1 + Math.abs(score - HALF_SCORE);
});
}
}
for(char[] chArray : CHARACTER){
int firstScore = sumScore.getOrDefault(chArray[0], 0);
int secondScore = sumScore.getOrDefault(chArray[1], 0);
// System.out.println(Arrays.toString(chArray)+" "+firstScore+","+secondScore);
if(firstScore >= secondScore){
answer += chArray[0];
}else{
answer += chArray[1];
}
}
return answer;
}
}