본문 바로가기
알고리즘

Algorithm - 주사위 게임

by DGK 2021. 11. 2.

 

알고리즘 입문 수업을 듣고 중요한 내용을 정리했습니다.
개인 공부 후 자료를 남기기 위한 목적이므로 내용 상에 오류가 있을 수 있습니다.

 

문제

[주사위 게임]

 

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명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받는 사람의 상금을 출력하는 프로그램을 작성하시오.

 

 

*입력 설명

첫 번째 줄에는 참여하는 사람의 수 N(2 ≤ N ≤ 1,000)이 주어진다.

두 번째 줄부터는 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 두고 각각 주어진다.

 

*출력 설명

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

 

 


 

 

풀이(Python)

답안

import sys
sys.stdin = open('AA/input_9.txt', 'rt')

n = int(input())
res = 0

for i in range(n):
    tmp = input().split()
    tmp.sort()
    a, b, c = map(int, tmp)
    if a == b and b == c:
        money = 10000 + (a * 1000)
    elif a == b or a == c:
        money = 1000 + (a * 100)
    elif b == c:
        money = 1000 + (b * 100)    
    else:
        money = c * 100
    if money > res:
        res = money

print(res)

# 출력 : 12000

 

input_9.txt(입력)

3
3 3 6
2 2 2
6 2 5

 

 

중요내용

3개 숫자 중 2개만 같은 경우의 수는 총 3가지 인데, 상금 계산을 편리하게 하기위해 위의 답안처럼 elif문의 조건을 a == b and a == c 와 b == c 두 가지로 나눈 것이다. 

 

 

'알고리즘' 카테고리의 다른 글

Algorithm - 회문 문자열 검사  (0) 2021.11.07
Algorithm - 점수 계산  (0) 2021.11.02
Algorithm - 뒤집은 소수  (0) 2021.11.02
Algorithm - 소수의 개수(에라토스테네스 체)  (0) 2021.11.02
Algorithm - 자릿수의 합  (0) 2021.11.02

댓글