[자바 Java] 배열 오름차순 정렬, 최대값 활용

2024. 1. 16. 17:24개발공부/Java

728x90
반응형

백준 알고리즘 2480문제


1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.
예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3×100으로 계산되어 1,300원을 받게 된다. 또 3개의 눈이 2, 2, 2로 주어지면 10,000+2×1,000 으로 계산되어 12,000원을 받게 된다. 3개의 눈이 6, 2, 5로 주어지면 그중 가장 큰 값이 6이므로 6×100으로 계산되어 600원을 상금으로 받게 된다.
3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

 

1. 배열 & for 문으로 최대값 만들고 활용하기

- 최대값 만들기

int[] num = {num1, num2, num3};
int maxNum = 0;
for (int i = 0; i < num.length; i++) {
    if (maxNum < num[i]) {
        maxNum = num[i];
    }
}

 

최대값을 선언한 뒤 조건문 실행

if (num1 < 1 || num1 > 6 || num2 < 1 || num2 > 6 || num3 < 1 || num3 > 6) {
            System.out.println("잘못된 입력입니다.");
            return;
        }  //예외처리

        // 세 수가 모두 같을 때
        if ( num1 == num2 && num2 == num3)  {
            reward = 10000 + (num1 * 1000);  
        } // 두 수가 모두 같을 때
          else if (num1 == num2) {
            reward = 1000 + (num1 * 100);
        } else if (num2 == num3) {
            reward = 1000 + (num2 * 100);
        } else if (num1 == num3) {
            reward = 1000 + (num3 * 100);
        } else {
            reward = maxNum * 100;
        }
        System.out.println(reward);
    }
}

※reward 미리 선언해놓아야 함.

 

2. 배열 만들고 오름차순 정렬 활용하기

배열 생성 후 Array.sort()로 오름차순 만들기

//오름차순 정렬
int[] num = {num1, num2, num3};
Arrays.sort(num);

 

주사위 숫자 예외처리 (배열 활용)

//예외처리
for (int i = 0; i < num.length; i++) {
    if (num[i] < 1 && num[i] > 6) {
        System.out.println("잘못된 입력입니다.");
    }
}  

 

리워드 계산 (변수 reward는 미리 선언)

if ( num[0] == num[3])  {// 세 수가 모두 같을 때
    reward = 10000 + (num[0] * 1000);
} else if ( num[0] == num[1]) {// 두 수가 같을 때
    reward = 1000 + (num[1] * 1000);
} else if (num[1] == num[2]) {// 두 수가 같을 때
    reward = 1000 + (num[2] * 1000);
} else {//모두 다를 때
    reward = num[2] * 100;
}
System.out.println(reward);

 

 

여기서 마지막 조건식 전체를 하나의 메서드로 리팩토링하여 식을 작성하면 main 메서드의 실행문을 보다 간결하게 만들 수 있을 것 같다. 

728x90
반응형