-
2476번 : 주사위 게임알고리즘 공부/백준 Python 코딩테스트 2021. 10. 14. 14:31
[ 문제 ]
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원을 상금으로 받게 된다.N(2 ≤ N ≤ 1,000)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.
[ Input ]
첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
[ Output ]
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
[ 풀이 ]
이 문제는 이전에 풀었던 '주사위 세개' 의 답안을 가져와서 함수로 이용한다.
2021.10.13 - [백준 Python 코딩테스트] - 2480번 : 주사위 세게
참가자의 주사위 눈이 들어오면 함수를 이용해서 상금을 계산하고 상금 list에 append 한다.
그리고 list안에서 최댓값을 print 하면된다.
만약에 몇 번째 참가자가 최대의 상금을 타는지까지가 필요하다면, list가 아닌 dict 형식으로 key는 참가자의 번호, value는 상금으로 추가한다. value 중 최대값을 찾아서 index로 찾아주면 된다.
[ 코드 ]
# 상금 계산 함수 def get_reward(dice_list): dice_list = sorted(dice_list) dice_set = set(dice_list) if len(dice_set) == 3: reward = max(dice_set) * 100 elif len(dice_set) == 1: reward = 10000 + dice_list[0] * 1000 else: reward = 1000 + dice_list[1] * 100 return reward # 참가자 수 input N = int(input()) # 상금 list reward_list = [] # 각 참가자별로 상금 저장 for _ in range(N): dice_list = list(map(int, input().split())) reward = get_reward(dice_list) reward_list.append(reward) # 가장 큰 값 print print(max(reward_list))
'알고리즘 공부 > 백준 Python 코딩테스트' 카테고리의 다른 글
2884번 : 알람 시계 (0) 2021.10.14 2754번 : 학점 계산 (0) 2021.10.14 3009번 : 네 번째 점 (0) 2021.10.13 2480번 : 주사위 세개 (0) 2021.10.13 1934번 : 최소공배수 (0) 2021.10.13