3 minute read

주사위 세개

문제

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.

  1. 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
  2. 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
  3. 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

입력

첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.

출력

첫째 줄에 게임의 상금을 출력 한다.

예제 입력 1

3 3 6

예제 출력 1

1300

예제 입력 2

2 2 2

예제 출력 2

12000

예제 입력 3

6 2 5

예제 출력 3

600



풀이

package backjoon;
import java.util.Scanner;

public class N2480 {
	public static void main(String[] args) {
			Scanner sc = new  Scanner(System.in);
			int N1 = sc.nextInt();
			int N2 = sc.nextInt();
			int N3 = sc.nextInt();
			int money;
			
			if(N1 == N2 && N2 == N3) {
				money = 10000 + N1 * 1000; 
			}
			else if((N1 != N2 && N2 != N3)){
				if (N1 > N2  && N1 > N3) {
					money=  N1 * 100; 
				}
				else if  (N2 > N3  && N2 > N1) {
					money=  N2 * 100; 
				}
				else {
					money=  N3 * 100; 
				}
			}			
			else if ( N1 == N2 && N1 != N3){
				money = 1000 + N1 * 100; 
			}
			else if ( N2 == N3 && N1 != N3){
				money = 1000 + N2 * 100; 
			}
			else {
				money = 1000 + N3 * 100; 
			}
			System.out.println(money);
			sc.close();
	}
}

처음 문제를 접했을 땐 쉽게 코드를 작성했으나, 코드가 길고 가독성이 안좋다고 판단하여 간결하고 가독성이 좋은 코드를 작성할 수 있도록 다시 문제를 풀었던 기억이 나는 코드이다. 🤦🏻‍♂️



import java.util.Scanner;

public class N2480 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N1 = sc.nextInt();
        int N2 = sc.nextInt();
        int N3 = sc.nextInt();
        int money;

        if (N1 == N2 && N2 == N3) {
            money = 10000 + N1 * 1000;
        } else if (N1 != N2 && N2 != N3) {
            money = Math.max(N1, Math.max(N2, N3)) * 100;
        } else if (N1 == N2 && N1 != N3) {
            money = 1000 + N1 * 100;
        } else if (N2 == N3 && N1 != N3) {
            money = 1000 + N2 * 100;
        } else {
            money = 1000 + N3 * 100;
        }
        
        System.out.println(money);
        sc.close();
    }
}

Math.max(인자1, 인자2) 해당 함수를 사용하여 3개의 수 중의 가장 큰 수가 무엇인지 쉽게 걸러낼 수 있게 되었고, 처음 풀었던 코드 보다는 가독성이 좋아졌지만 이대로 제출하니 틀렸다고 나오는 바람에 원인이 뭘까 하고 열심히 생각해보았다..



import java.util.Scanner;

public class N2480 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N1 = sc.nextInt();
        int N2 = sc.nextInt();
        int N3 = sc.nextInt();
        int money;

        if (N1 == N2 && N2 == N3) {
            money = 10000 + N1 * 1000;
        } else if (N1 != N2 && N2 != N3 && N1 != N3) {
            money = Math.max(N1, Math.max(N2, N3)) * 100;
        } else if (N1 == N2 && N1 != N3) {
            money = 1000 + N1 * 100;
        } else if (N2 == N3 && N1 != N3) {
            money = 1000 + N2 * 100;
        } else {
            money = 1000 + N3 * 100;
        }
        
        System.out.println(money);
        sc.close();
    }
}

문제가 뭘까 하고 샤워를 하면서 곰곰히 생각해 본 끝에 답을 찾았다!



정답은 else if문의 첫번째 구문이 원인 이였다.

[오답]

else if (N1 != N2 && N2 != N3) 

N1 은 N2와 같지 않고, N2는 N3과 같지 않다라고 작성을 했지만

[정답]

else if (N1 != N2 && N2 != N3 && N1 != N3)

위와 같이 N1, N2, N3 모두 틀리다는 것을 직접적으로 코드로 작성해주었다.

N1은 N2와 같지 않고 N2는 N3와 같지 않다는 코드가

“N1와 N3 도 같지 않다“ 라는 안일한 생각에;

이런 헤픈 실수를 해버린 것이다.. 🥲

즉 N1이 10이고, N2가 20이며, N3가 10 이라는 정수이면 N1 ≠ N3 이라는 형식이 틀리기 때문에 오답이 맞다! ..

Leave a comment