코딩테스트

[백준] 주사위 세개

SigmoidFunction 2022. 6. 16. 14:06
728x90

어찌 되었든 백준 브론즈 문제를 한번 맛보려고 풀어보았다.

 

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

출력

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

예제 입력 1 복사

3 3 6

예제 출력 1 복사

1300

예제 입력 2 복사

2 2 2

예제 출력 2 복사

12000

예제 입력 3 복사

6 2 5

예제 출력 3 복사

600

 

생각보다 너무 쉬워서 어떻게 하면 단순하고 효율적으로 짤 수 있을까를 고민했던 것 같다.

 

어차피

 

3개만 들어오기때문에 세개만 비교해주면 간단하다.

 

set을 통해서 진행했다.

 

 

dice = list(map(int, input().split()))

result = 0
if len(set(dice)) == 1:
    result = (dice[0] * 1000) + 10000
    
elif len(set(dice)) == 2:
    if dice.count(list(set(dice))[0]) == 2:
        result = 1000 + list(set(dice))[0]*100
    else:
        result = 1000 + list(set(dice))[1]*100
else:
    result = max(dice) * 100
    
print(result)

 

728x90