알고리즘/Programmers
[Programmers_Java] 로또의 최고 순위와 최저 순위
씨네
2021. 7. 21. 22:05
728x90
https://programmers.co.kr/learn/courses/30/lessons/77484
로또 코드는 지겹도록 짜봤었습니다!
그래서 이것도 그런 문제인줄알고 봤더니...
단순한 로또 문제가 아니라 해당 번호로 나올수 있는 최고 순위와 최저 순위를 구하는 문제였더라구요...
진짜 5분이면 다 풀 줄 알았는데 생각보다 고민을 조금 했습니다!
import java.util.Arrays;
class Solution {
public int[] solution(int[] lottos, int[] win_nums) {
int count = 0;
int min = 0;
int max = 0;
for(int i = 0; i < lottos.length; i++) {
for(int j = 0; j < win_nums.length; j++) {
if(lottos[i] == win_nums[j]) {
count++;
}
}
}
for(int i : lottos) {
if(i == 0) {
max++;
}
}
switch(count) {
case 0: min = 6; case 1: min = 6;
break;
case 2: min = 5;
break;
case 3: min = 4;
break;
case 4: min = 3;
break;
case 5: min = 2;
break;
case 6: min = 1;
break;
}
switch(count + max) {
case 0: max = 6; case 1: max = 6;
break;
case 2: max = 5;
break;
case 3: max = 4;
break;
case 4: max = 3;
break;
case 5: max = 2;
break;
case 6: max = 1;
break;
}
int[] answer = {max, min};
return answer;
}
}
우선 0이 아닌 것의 순위를 구하고 최고 순위는 0이 모두 번호가 맞았을경우라고 가정하고 계산을하고 최저 순위는 모두 틀렸다고 가정하고 계산하면 쉽게 풀수 있습니다!
728x90