반응형
시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 | 128 MB | 72282 | 35407 | 31091 | 49.848% |
문제
1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
- 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
- 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
- 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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
더보기
from collections import Counter
# 1차 입력값 처리
def chkInput(testCase=None):
# 케이스 반복 횟수 체크
caseLength = len(testCase)
# 입력값이 3개가 아닐 때
if caseLength != 3:
raise Exception('입력값이 3개가 아닙니다.')
for index in range(0, caseLength):
# 주사위 값이 잘못 되었을 때
if not (1 <= testCase[index] <= 6):
raise Exception('입력값의 범위가 잘못되었습니다.')
# 결과값 계산
def calOutput(testCase=None):
funcResult = 0
numberA = testCase[0] # 1번째 수
numberB = testCase[1] # 2번째 수
dupList = dict(Counter(testCase)) # 중복 수 확인
# ex 3 3 6
# 딕셔너리 {3: 2, 6: 1}
# 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
if dupList.get(numberA) == 3:
funcResult = 10000 + (numberA*1000)
# 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
elif dupList.get(numberA) == 2:
funcResult = 1000 + (numberA*100)
elif dupList.get(numberB) == 2:
funcResult = 1000 + (numberB*100)
# 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.
elif dupList.get(numberA) == 1:
funcResult = max(testCase)*100
return funcResult
try:
caseInputList = list(map(int, input().split()))
chkInput(caseInputList)
print(calOutput(caseInputList))
except Exception as e:
print(e)
반응형
'IT > Programming' 카테고리의 다른 글
[백준, Python] 10156번 과자 (0) | 2022.07.22 |
---|---|
[백준, Python] 1934번 최소공배수 (0) | 2022.07.22 |
[백준, Python] 10039번 평균 점수 (0) | 2022.07.11 |
[백준, Python] 2753번 윤년 (0) | 2022.07.11 |
[백준, Python] 11653번 소인수분해 (0) | 2022.07.09 |