반응형
SMALL
문제
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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
내 코드
import java.util.Scanner;
public class backjoon_2480 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int num1 = scanner.nextInt();
int num2 = scanner.nextInt();
int num3 = scanner.nextInt();
int result = 0;
if(num1 == num2 && num1 == num3 && num2 == num3){
//모두 같을 시 그냥 num1을 조건에 더해준다
result = 10000 + num1 * 1000;
}else if(num1 == num2 && num1 != num3 || num1 == num3 && num2 != num3 || num1 != num2 && num2 == num3){
//만약 세가지 숫자중 num1과 num3이 같다면
if(num1 == num3){
//num1에 num3값을 넣어준다.
num1 = num3;
}
//만약 세가지 숫자중 num1과 num2가 같다면
if(num1 == num2){
//num1에 num3값을 넣어준다
num1 = num2;
}
//만약 세가지 숫자중 num2와 num3이 같다면
if(num2 == num3){
//num2에 값을 num1에 넣어준다
num1 = num2;
}
result = 1000 + num1 * 100;
}else if(num1 != num2 && num1 != num3 ){
//만약 입력 받은 숫자를 4 2 5 라고 치겠다
//제일 큰 숫자를 더해주기 위해 if문에서 num1과 num3의 크기를 비교해준다
if(num1 < num3){
//true라면 num1에 num3에 값을 넣어준다
num1 = num3;
}
//2 5 3 이라고 치겠다
//제일 큰 숫자를 더해주기 위해 if문에서 num1과 num2의 크기를 비교해준다
if(num1 < num2){
//true라면 num1에 num2에 값을 넣어준다
num1 = num2;
}
result = num1 * 100;
}
System.out.println(result);
}
}
이번 문제는 백준 if문 파트의 마지막 문제 주사위 세개 문제이다.
첫번째 조건은 모두다 같은 경우라서 정말 쉽게 풀이했다. 하지만 두번째 조건 " 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다. " 라는 조건을 풀이할 때에는 2가지의 숫자만 맞고 1가지의 숫자만 다른 경우의 수를 짜주기 위해서 비교적 길어진 if문 조건을 작성하게 되어 딱히 마음에 들지 않는다..
레퍼런스
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
int b = sc.nextInt();
int c = sc.nextInt();
if(a == b && a == c && b == c)
{
System.out.print(10000+(a*1000));
}
else if(a == b || a == c)
{
System.out.print(1000+(a*100));
}
else if(b == c)
{
System.out.print(1000+(b*100));
}
else
{
System.out.print((Math.max(a, Math.max(b, c))*100));
}
}
}
위 코드는 세가지의 경우가 모두 다를 경우 Math.max 메서드를 사용하여 문제를 풀이하여주었다.
레퍼런스 코드는 참 코드가 간결하고 보기 좋아서 내가 짠 코드를 보며 반성하게 되는 것 같다.. 다음에는 문제 풀이에도 집중하지만 좋은 코드를 짜기위해 노력해야할 것 같다
LIST
'Programming > algorithm' 카테고리의 다른 글
[Algorithm] 백준 2525번 : 오븐 시계 (0) | 2022.06.08 |
---|