[codeup] 4691 : 주사위 네 개

SUNGJIN KIM·2022년 9월 11일
0

CODEUP

목록 보기
65/76
post-thumbnail

문제

문제1) 주사위 네개(고등1)

1에서부터 6까지의 눈을 가진 4개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.

규칙(1) : 같은 눈이 4개가 나오면 50,000원+(같은 눈)*5,000원의 상금을 받게 된다.

규칙(2) : 같은 눈이 3개만 나오면 10,000원+(3개가 나온 눈)*1,000원의 상금을 받게 된다.

규칙(3) : 같은 눈이 2개씩 두 쌍이 나오는 경우에는 2,000원+(2개가 나온 눈)500원+(또 다른 2개가 나온 눈)500원의 상금을 받게 된다.

규칙(4) : 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)*100원의 상금을 받게 된다.

규칙(5) : 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)*100원의 상금을 받게 된다.

예를 들어, 4개의 눈이 3, 3, 3, 3으로 주어지면 50,000+3*5,000으로 계산되어 65,000원의 상금을 받게 된다.

4개의 눈이 3, 3, 6, 3으로 주어지면 상금은 10,000+3*1,000으로 계산되어 13,000원을 받게 된다.

또 4개의 눈이 2, 2, 6, 6으로 주어지면 2,000+2500+6500으로 계산되어 6,000원을 받게 된다.

4개의 눈이 6, 2, 1, 6으로 주어지면 1,000+6*100으로 계산되어 1,600원을 받게 된다.

4개의 눈이 6, 2, 1, 5로 주어지면 그 중 가장 큰 값이 6이므로 6*100으로 계산되어 600원을 상금으로 받게 된다. n(1 ≤ n ≤ 1,000)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.

입력

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

입력 예시

4
3 3 3 3
3 3 6 3
2 2 6 6
6 2 1 5

출력

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

출력 예시

65000

문제 풀이

처음에 어떤 식으로 문제를 풀어야할지 엄청 고민했다.
처음 풀었던 방식은 아래와 같았는데, 이 방식으로 풀었을때 케이스 하나가 답이 출력되지 않았다.

그래서 열심히 구글링하고, 방법을 조금 바꿨더니 드디어 풀렸다.
이렇게 쉽게 풀릴걸 뭐이렇게 돌아왔는지..

participant = int(input())
dice_number = []

# case 1. 중복제외한 주사위 수 집합의 길이로 확인
def chk_dupDiceNum(dice_number):
  # 4개의 수가 모두 같은 경우
  if len(set(dice_number)) == 1:
    return 50000 + dice_number[0] * 5000
  # 2개의 수가 모두 같은 경우 (2가지 케이스) 3 3 3 1 , 2 2 3 3
  elif len(set(dice_number)) == 2:
    if dice_number[1] == dice_number[2]:
      return 10000 + dice_number[3] * 1000
    else:
      return 2000 + dice_number[1] * 500 + dice_number[2] * 500
  # 2개의 수만 같은 경우 (ex 1 1 2 3)
  elif len(set(dice_number)) == 3:
    for i in range(len(dice_number)):
      if dice_number[i] == dice_number[i+1]:
        return 1000 + dice_number[i] * 100
  # 모든 수가 다른 경우
  else:
    return dice_number[3] * 100


# 주사위 수 받기 (int - list)
for cnt in range(participant):
    num = sorted(list(map(int, input().split())))
    dice_number.append(chk_dupDiceNum(num))

print(max(dice_number))
profile
#QA #woonmong

0개의 댓글