[백준] 2480 주사위 세개
주사위 세개
- 티어 : Bronze 4
- 시간 제한 : 1 초
- 메모리 제한 : 128 MB
- 알고리즘 분류 : 수학, 사칙연산
문제
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개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력
첫째 줄에 게임의 상금을 출력 한다.
예제 입출력
Algorithm
1. 입력 값을 Dictionary에 추가 (개수 count)
2. for문을 돌면서 value가 3이면 10000 + key * 100
3. value가 2이면 1000 + key * 100
4. 그 외의 상황이면 max(key) * 100
Code
# 입력
data = list(map(int, input().split()))
# 입력 값 Dictionary에 저장 (key: 입력 값, value: 횟수)
dict_ = {}
for i in data:
if i not in dict_:
dict_[i] = 1
else:
dict_[i] += 1
flag = False # 같은 숫자가 있는 경우 False, 모두 다른 경우 True
for key, value in dict_.items():
if value == 3:
print(10000 + key * 1000)
flag = False
break
elif value == 2:
print(1000 + key * 100)
flag = False
break
else:
flag = True
if flag:
print(max(dict_.keys()) * 100)
메모리: 30864 KB
시간: 68 ms
Author And Source
이 문제에 관하여([백준] 2480 주사위 세개), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@jy5122/백준-2480-주사위-세개저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)