개발일기

백준 2476번 파이썬 풀이 : 주사위 게임 본문

알고리즘 문제풀이/백준

백준 2476번 파이썬 풀이 : 주사위 게임

한민기 2021. 10. 4. 21:06
반응형

문제 링크 : https://www.acmicpc.net/problem/2476

 

2476번: 주사위 게임

첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다. 

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원을 상금으로 받게 된다.

N(2 ≤ N ≤ 1,000)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.

입력

첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다. 

출력

첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.

 

 

# 문제 풀이

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
= int(input())
max_money = 0
for _ in range(n):
    people = list(map(int, input().split()))
    temp = 0
    people.sort()
    if people[0== people[1== people[2]:
        temp = 10000 + people[0* 1000
    elif people[0== people[1]:
        temp = 1000 + people[0* 100
    elif people[1== people[2]:
        temp = 1000 + people[1* 100
    else:
        temp = max(people) * 100
 
    if max_money < temp:
        max_money = temp
print(max_money)
cs

 

문제에 설명되있는 대로 나열하면서 문제를 풀었다. 

 

하지만 다른 풀이와는 조금 다르게 주사위의 값들을 list 형태로 입력받아  sort 를 통해 정렬을 해준다.

 

이렇게 되면 a와 c가 같게 되는 경우는 a, b, c 총 3개의 값이 모두 같아야 한다.

 

따라서 조건문을 a = b = c, a = b, a = c, b = c, a != b != c 총 5번을 진행하지 않아도 된다.

 

반응형
Comments