[JAVA] 백준 2480번 : 주사위 세개
in Blog / Algorithm / Bronze IV / Bronze-iv on Algorithm, Baekjoon, Bronze
안녕하세요, 해을입니다🦖
이번 글에서는 백준 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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
💡 입력
첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
💡 출력
첫째 줄에 게임의 상금을 출력 한다.
💡 예제 입력 1
3 3 6
💡 예제 출력 1
1300
💡 예제 입력 2
2 2 2
💡 예제 출력 2
12000
🚩 문제 풀이
[주어진 값]
- 주사위 3개의 눈 : x, y, z
[구해야 할 값]
- 상금 : result
- 같은 눈 3개 : 10,000 + (같은 눈) * 1,000
- 같은 눈 2개 : 1,000 + (같은 눈) * 100
- 모두 다른 눈 : (그 중 가장 큰 눈) * 100
조건문을 사용하여 같은 눈의 개수에 따라 상금을 계산합니다.
모두 다른 눈이 나온 경우에는 가장 큰 눈을 구할 때, 최댓값 함수인 Math.max()를 사용합니다.
🚩 소스 코드
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int money;
int x = sc.nextInt();
int y = sc.nextInt();
int z = sc.nextInt();
sc.close();
if(x==y && y==z && x==z) {
money = 10000 + (x * 1000);
}else if(x==y||x==z) {
money = 1000 + (x * 100);
}else if(y==z) {
money = 1000 + (y * 100);
}else {
money = Math.max(x, Math.max(y, z)) * 100;
}
System.out.println(money);
}
}
오류 및 오타 지적, 질문, 인사 등 무엇이든 언제나 환영입니다!
읽어주셔서 감사합니다.
끝!🦕