loading

알고리즘/알고리즘JAVA

[백준알고리즘/JAVA/if문] 2480번 문제 : 주사위 세개

침착곰 2023. 5. 30. 21:09
반응형

안녕하세요!

백준 알고리즘에서 단계별로 풀어보기 조건문의 2480번 문제 "주사위 세개"를 풀어보고 난 후 코드와 해설을 포스팅하겠습니다.

 

https://www.acmicpc.net/problem/2480

 

2480번: 주사위 세개

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.  같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.  같은 눈이 2개

www.acmicpc.net

 

문제

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

 

출력

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

 

 


문제풀이

문제는 특별히 어려운 점이 없습니다. 조건문 그대로 if - case문을 사용해서 구해주면 됩니다.

 


정답

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

public class Main {
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine(), " ");
		
		int A = Integer.parseInt(st.nextToken());
		int B = Integer.parseInt(st.nextToken());
		int C = Integer.parseInt(st.nextToken());
		int rslt;
        
		// 주사위 3개가 같을 때
        if(A == B && B == C) {
        	rslt = 10000 + (A * 1000);
        }
        // 주사위 3개가 다를 때
        else if(A != B && B != C && A != C) {
        	if(A < B) {
        		if(B < C) {
        			rslt = C * 100;
        		} else {
        			rslt = B * 100;
        		}
        	} else {
        		if(A < C) {
        			rslt = C * 100;
        		} else {
        			rslt = A * 100;
        		}
        	}
        } 
        // 주사위 2개가 같을 때
        else {
        	if(A == B) {
        		rslt = 1000 + (A * 100);
        	} else if(B == C) {
        		rslt = 1000 + (B * 100);        		
        	} else {
        		rslt = 1000 + (A * 100);        		
        	}        	
        }

		System.out.print(rslt);
	}
}

1. 세 개의 주사위 눈이 모두 같은 경우:
A, B, C가 모두 같을 때, 상금은 10,000원에 같은 눈(A)을 곱한 값(1,000원)을 더한 값입니다. 따라서 rslt 변수에 10,000 + (A * 1,000)을 저장합니다.

2. 세 개의 주사위 눈이 모두 다른 경우:
A, B, C가 모두 다를 때, 가장 큰 눈을 찾아서 상금을 계산합니다.
각각의 경우에 대해 A < B < C 조건을 확인하고, 가장 큰 눈에 100을 곱한 값을 rslt에 저장합니다.

3. 두 개의 주사위 눈이 같은 경우:
A와 B가 같거나, B와 C가 같거나, A와 C가 같을 때, 상금은 1,000원에 같은 눈을 곱한 값(100원)을 더한 값입니다. rslt에 1,000 + (같은 눈 * 100)을 저장합니다.

 

이상 백준 알고리즘 2480번 주사위 세개를 풀은 내용이었습니다. 추가적인 질문이 있으시면 언제든지 물어보세요!

 

이전 글 : 2023.05.30 - [알고리즘/알고리즘JAVA] - [백준알고리즘/JAVA/if문] 2525번 문제 : 오븐 시계

반응형
그리드형