인사고과
2025-01-09
#JAVA#프로그래머스
문제 풀이 시간 : 1시간
문제 풀이 :
이 문제는 프로그래머스에서 레벨3 중에 좀 그나마 쉬워보여서 선택했다.
일단 재활훈련이 시급하기 때문에..
처음에는 그냥 두 점수의 합을 기준으로 정렬을 해서 그냥 완호의 석차만 계산해주면 되는거 아닌가?
라는 생각으로 코드를 짰다.
초기 코드
import java.util.*;
class Solution {
public int solution(int[][] scores) {
int answer = 0;
int[] wonho = new int[2];
wonho[0] = scores[0][0];
wonho[1] = scores[0][1];
Arrays.sort(scores, new Comparator<int[]>(){
@Override
public int compare(int[] a, int[] b){
return (b[0]+b[1]) - (a[0]+a[1]);
}
});
int score = 0;
for(int i=0;i<scores.length;i++){
score++;
if(scores[i][0]==wonho[0]&&scores[i][1]==wonho[1]){
break;
}
if(scores[i][0]>wonho[0]&&scores[i][1]>wonho[1]){
score = -1;
break;
}
}
return score;
}
}
이렇게 하면 대부분의 테스트케이스를 통과할 수 있다.
하지만 75점 정도로 완벽하게 맞지는 못한다.
그 이유는?
[[7, 1], [6, 6], [5, 4], [5, 4], [6, 6]]
위와 같은 테스트 케이스가 있다면
내가 짠 코드에서는
[6, 6]
[6, 6]
[5, 4]
[5, 4]
[7, 1]
이렇게 정렬이 될 것이다.
그래서 [7, 1]인 완호는 5등으로 출력이 되지만
실제로 [5, 4]는 [6, 6]보다 두 점수 모두 낮기 때문에 석차에 포함되지 않게 된다.
따라서 완호가 아닌 경우라도 점수를 확인해주며 인센티브를 받을 자격이 있는지 확인하는 과정이 필요하다.
근데 이 과정을 어떻게 해야할까?
나는 처음에 for문 안에서 한번더 for문을 사용해서 확인하면 쉽게 되겠다라고 생각했는데
scores의 길이가 최대 100,000이라 시간초과가 날 것이라고 생각하고 다른 방법을 생각해보았다.
근데 아무리 생각해도 마땅히 좋은 방법이 떠오르지 않아서
그냥 위의 방법을 사용해봤더니
아주 쉽게 통과를 해버렸다..ㅎ
최종 코드
import java.util.*;
class Solution {
public int solution(int[][] scores) {
int answer = 0;
int[] wonho = new int[2];
wonho[0] = scores[0][0];
wonho[1] = scores[0][1];
Arrays.sort(scores, new Comparator<int[]>(){
@Override
public int compare(int[] a, int[] b){
return (b[0]+b[1]) - (a[0]+a[1]);
}
});
int score = 0;
for(int i=0;i<scores.length;i++){
score++;
if(scores[i][0]==wonho[0]&&scores[i][1]==wonho[1]){
break;
}
if(scores[i][0]>wonho[0]&&scores[i][1]>wonho[1]){
score = -1;
break;
}
for(int j=0;j<i;j++){
if(scores[j][0]>scores[i][0]&&scores[j][1]>scores[i][1]){
score-=1;
break;
}
}
}
return score;
}
}