코딩테스트/백준

[백준] 2480 주사위 세개

민톨이 2024. 10. 15. 19:15
728x90

📋 문제

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개의 눈이 빈칸을 사이에 두고 각각 주어진다.

 

📋 출력

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

 

 


📋 풀이

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        //입력 3개
        int a = sc.nextInt();
        int b = sc.nextInt();
        int c = sc.nextInt();
        int money = 0;

        if(a==b&&b==c){ //같은 눈 3개
            money = 10000 + (a*1000);
        } else if(a==b||a==c||b==c){ // 같은 눈 2개
            if(a==b||a==c){
                money = 1000 + (a*100);
            } else{
                money = 1000 + (b*100);
            }

        } else { //모두 다른 눈
            int max = Math.max(a, Math.max(b,c)); //셋 중 가장 큰 눈 구하기
            money = max * 100;
        }
        System.out.println(money);
    }
}

 

조건문에 같은눈 n개 / 모두 다른 눈 처리 로직 적어둠

 

Math.max(a,b)

최댓값 구하기 함수 사용 (사실 기억 안나서 찾아보고 품 ㅋㅋ)

 

두 인자까지만 비교 가능한 것 같아서 3개를 비교하기 위해 Math.max() 2회 사용

=> b,c 중에 큰 애 구하고 a랑 비교했다

 

 

 

'코딩테스트 > 백준' 카테고리의 다른 글

[백준] 10773 제로  (1) 2024.10.20
[백준] 10818 최소, 최대  (0) 2024.10.17
[백준] 10871 X보다 작은 수  (0) 2024.10.17
[백준] 9086 문자열  (1) 2024.10.13
[백준]11720 - 숫자의 합  (0) 2024.10.10