1 분 소요

1. 문제

https://www.acmicpc.net/problem/2484

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

같은 눈이 4개가 나오면 50,000+(같은 )×5,000원의 상금을 받게 된다.
같은 눈이 3개만 나오면 10,000+(3개가 나온 )×1,000원의 상금을 받게 된다.
같은 눈이 2개씩  쌍이 나오는 경우에는
2,000+(2개가 나온 )×500+( 다른 2개가 나온 )×500원의 상금을 받게 된다.
같은 눈이 2개만 나오는 경우에는 1,000+(같은 )×100원의 상금을 받게 된다.
모두 다른 눈이 나오는 경우에는 (  가장  )×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+2×500+6×500으로 계산되어 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개의 눈이 빈칸을 사이에 두고 각각 주어진다.

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

// 예제 입력 1
4
3 3 3 3
3 3 6 3
2 2 6 6
6 2 1 5

// 예제 출력 1
65000


2. 핵심 아이디어

  • 조건에 부합하게 구현


3. Python 문제풀이

import sys
input = sys.stdin.readline

def reward() :
  dice = sorted(list(map(int, input().split())))
  if len(set(dice)) == 1 :
    return 50000 + dice[0] * 5000
  if len(set(dice)) == 2 :
    if dice[1] == dice[2] :
      return 10000 + dice[1] * 1000
    else :
      return 2000 + (dice[1] + dice[2]) * 500
  for i in range(3) :
    if dice[i] == dice[i + 1] :
      return 1000 + dice[i] * 100
  return dice[-1] * 100

n = int(input())

print(max(reward() for i in range(n)))


4. Java 문제풀이


댓글남기기