B2480 주사위 세개
날짜 | 2024-03-27 |
사용 언어 | Java |
문제 유형 | 사칙연산, 많은 조건 분기, 구현, 수학 |
정답률 | 46.987% |
문제 URL | https://www.acmicpc.net/problem/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개의 눈이 빈칸을 사이에 두고 각각 주어진다.
- 첫째 줄에 게임의 상금을 출력 한다.
나의 풀이 #
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) throws Exception {
Scanner sc = new Scanner(System.in);
int[] dices = Arrays.stream(sc.nextLine().split(" "))
.mapToInt(Integer::parseInt)
.sorted()
.toArray();
int reward = 0;
// 눈금은 정렬되어 있기 때문에 조건이 간략해짐
if (dices[0] == dices[2]) {
reward = 10000 + dices[0] * 1000;
} else if (dices[0] == dices[1] || dices[1] == dices[2]) {
reward = 1000 + dices[1] * 100;
} else {
reward = dices[2] * 100;
}
System.out.println(reward);
}
}
다른 사람의 풀이 #