[파이썬][백준 2476번] 주사위 게임
1. 문제Permalink
[Bronze III] 주사위 게임 - 2476Permalink
성능 요약Permalink
메모리: 30840 KB, 시간: 68 ms
분류Permalink
구현(implementation), 수학(math)
문제 설명Permalink
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)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.
입력Permalink
첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력Permalink
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
출처: 백준, https://https://www.acmicpc.net/
2. 해결방법 시간복잡도Permalink
- 단순 코딩 O(N)
3. 문제 해결 및 코드Permalink
import sys | |
input = sys.stdin.readline | |
T = int(input()) | |
result = [] | |
for i in range(T): | |
H = list(map(int, input().split())) | |
if H[0] == H[1] == H[2]: | |
result.append(10000 + H[1] * 1000) | |
elif H[0] == H[1] or H[1] == H[2]: | |
result.append(1000 + H[1] * 100) | |
elif H[0] == H[2]: | |
result.append(1000 + H[0] * 100) | |
else: | |
result.append(max(H) * 100) | |
print(max(result)) |
-
주석을 참고하면서 이해를 돕습니다.Permalink
4. 알고리즘 및 해설Permalink
- T만큼 반복문이 돌면서 계속해서 값을 받는다.
- 이때 해당 값들을 if문을 통해 경우의 수를 계산하여 결과값에 값을 넣어준다.
- 같은 눈이 3개가 나오는 경우
- 같은 눈이 2개만 나오는 경우
- 모두 다른 눈이 나오는 경우
- 위의 3가지 경우를 제외한 경우
- 결과 리스트중 가장 큰 값을 출력해준다.