본문 바로가기

코딩 테스트

[백준] (2480번) 주사위 세개

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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

 

 

- 입력 예시 -

 

// (case 1)
3 3 6

// (case 2)
2 2 2

// (case 3)
6 2 5

 

출력 예시  -

 

// (case 1)
1300

// (case 2)
12000

// (case 3)
600

정답 코드


<  내 정답 코드  >

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String nums = br.readLine();
        int firstNum = Integer.parseInt(nums.substring(0, 1));
        int secondNum = Integer.parseInt(nums.substring(2, 3));
        int thirdNum = Integer.parseInt(nums.substring(4, 5));
        int reward = 0;
        boolean isSameFirstAndSecond = firstNum == secondNum ? true : false;
        boolean isSameSecondAndThird = secondNum == thirdNum ? true : false;
        boolean isSameFirstAndThird = firstNum == thirdNum ? true : false;

        if (isSameFirstAndSecond && isSameSecondAndThird) {
            reward = firstNum * 1000 + 10000;
        } else if (isSameFirstAndSecond) {
            reward = firstNum * 100 + 1000;
        } else if (isSameSecondAndThird) {
            reward = secondNum * 100 + 1000;
        } else if (isSameFirstAndThird) {
            reward = firstNum * 100 + 1000;
        } else {
            if (firstNum > secondNum && firstNum > thirdNum) {
                reward = firstNum * 100;
            } else if (secondNum > firstNum && secondNum > thirdNum) {
                reward = secondNum * 100;
            } else {
                reward = thirdNum * 100;
            }
        }

        System.out.println(reward);
    }
}

이것을 주의하자!


-  좀 복잡하긴 한데 하나씩 차근차근 풀면 어렵지 않다. 모든 경우의 수를 고려하였다.

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

[백준] (2753번) 윤년  (0) 2022.11.19
[백준] (2525번) 오븐 시계  (0) 2022.11.19
[백준] (2444번) 별 찍기 - 7  (0) 2022.11.19
[백준] (2443번) 별 찍기 - 6  (0) 2022.11.19
[백준] (2442번) 별 찍기 - 5  (0) 2022.11.19