[백준] 2480번 문제 - 주사위 세개 - JAVA(자바)
문제
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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
입력
첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력
첫째 줄에 게임의 상금을 출력 한다.
이 문제는 각각의 조건을 if / else if 로 주어서 출력하면 될거라 생각하였고 조금 복잡하지만
코드를 짜보았다.
package baekjoon;
import java.util.Scanner;
public class b2480 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int A = sc.nextInt();
int B = sc.nextInt();
int C = sc.nextInt();
int a = 10000;
int b = 1000;
int c = 100;
if (A == B && B == C && C == A) {
System.out.println(a + A * b);
} else if (A == B || B == C || C == A) {
if (A == B || A == C) {
System.out.println(b + A * c);
} else if (B == C) {
System.out.println(b + B * c);
}
} else {
if (A > B && A > C) {
System.out.println(A * c);
} else if (B > A && B > C) {
System.out.println(B * c);
} else if (C > A && C > B) {
System.out.println(C * c);
}
}
}
}
아주 상세하게 오류가 생기지 않게 하기위해서 없어도 될 수식까지 넣어가면서 코드를 짜보았고
물론 답은 정확하게 나왔지만 이것보다 더 간단하게 표현 할 수 있는 코드가 없을 까 해서 찾아보았다.
이쪽 함수는 같은 눈이 2개만 나오는 경우를 설정해 놓았는데 이 경우 다른사람들은
else if (A == B || B ==C) 와
else if (A == C) 이 두 조건으로 마무리 지었고
이후
이 세개의 숫자가 하나도 일치하지 않을 때에는 그냥 else로 하면 조건이 충족된다는것을 ... 다 쓰고나서야 알았다.. 문제에
갖혀있었던 나..
세개의 숫자중 가장 큰 숫자를 뽑아낼때에는
Math.max(a,b) 메서드를 사용한것도 배웟으며
각 조건당 System.out.print를 하는것이 아닌 result 그러니까 결과값을 받을 변수만 지정해놓고
제일 마지막에 참인 조건에서 나온 답만 출력하게 끔 하는 그런 코드도 보았다.
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int A = input.nextInt();
int B = input.nextInt();
int C = input.nextInt();
int R = 0;
if (A == B && B == C && A == C) {
R = 10000 + A * 1000;
}
else if (A == B || A == C) {
R = 1000 + A * 100;
}
else if (B == C) {
R = 1000 + B * 100;
}
else {
R = Math.max(A, Math.max(B, C)) * 100;
}
System.out.println(R);
}
}
이와 같은 방식으로 아주 간단하게 표현 할 수도 있었던 것이다.
정말 문제를 풀면 풀수록 부족한점이 많다는것을 느꼈다.