ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • 2476번 : 주사위 게임
    알고리즘 공부/백준 Python 코딩테스트 2021. 10. 14. 14:31

    [ 문제 ]

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

    [ Input ]

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

    [ Output ]

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


    [ 풀이 ]

    이 문제는 이전에 풀었던 '주사위 세개' 의 답안을 가져와서 함수로 이용한다.

    2021.10.13 - [백준 Python 코딩테스트] - 2480번 : 주사위 세게

     

    참가자의 주사위 눈이 들어오면 함수를 이용해서 상금을 계산하고 상금 list에 append 한다.

    그리고 list안에서 최댓값을 print 하면된다.

     

    만약에 몇 번째 참가자가 최대의 상금을 타는지까지가 필요하다면, list가 아닌 dict 형식으로 key는 참가자의 번호, value는 상금으로 추가한다. value 중 최대값을 찾아서 index로 찾아주면 된다.

    [ 코드 ]

    # 상금 계산 함수
    def get_reward(dice_list):
        dice_list = sorted(dice_list)
        dice_set = set(dice_list)
    
        if len(dice_set) == 3:
            reward = max(dice_set) * 100
        elif len(dice_set) == 1:
            reward = 10000 + dice_list[0] * 1000
        else:
            reward = 1000 + dice_list[1] * 100
            
        return reward
            
    # 참가자 수 input
    N = int(input())
    # 상금 list
    reward_list = []
    # 각 참가자별로 상금 저장
    for _ in range(N):
        dice_list = list(map(int, input().split()))
        reward = get_reward(dice_list)
        reward_list.append(reward)
        
    # 가장 큰 값 print
    print(max(reward_list))

    '알고리즘 공부 > 백준 Python 코딩테스트' 카테고리의 다른 글

    2884번 : 알람 시계  (0) 2021.10.14
    2754번 : 학점 계산  (0) 2021.10.14
    3009번 : 네 번째 점  (0) 2021.10.13
    2480번 : 주사위 세개  (0) 2021.10.13
    1934번 : 최소공배수  (0) 2021.10.13

    댓글

Designed by Tistory.