백준/백준 파이썬

백준 파이썬 2484번 주사위 네개 (Today I Learn 2023.11.13)

군청레프 2023. 11. 15. 01:54
728x90

11/ 13 파이썬 공부

1. 백준 2484번 주사위 네개

 

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

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

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

>>>코드

# 점수를 저장할 리스트 생성
score = []
for _ in range(int(input())):
    dice = [0] * 6 # 리스트의 인덱스로 눈금 저장
    n = list(map(int,input().strip().split()))
    for i in n:
        dice[i-1] += 1
    if max(dice) == 4: # 같은 눈금이 4개일 경우
        score.append(50000 + (dice.index(4) + 1)*5000)
    elif max(dice) == 3: # 같은 눈금이 3개일 경우
        score.append(10000 + (dice.index(3) + 1)*1000)
    elif max(dice) == 2 and dice.count(2) == 2: # 같은 눈금이 2개인 것이 2쌍일 경우
        score.append(2000 + 500*(dice.index(2)+1+dice.index(2,dice.index(2)+1)+1))
    elif max(dice) == 2: # 같은 눈금이 2개인 것이 한쌍일 경우
        score.append(1000 + 100 * (dice.index(2) + 1))
    else: # 모든 눈금이 다를 경우
        k = 0
        for i in range(6):
            if dice[i] == 1:
                k += 1
            if k == 4:
                score.append(100 * (i+1))
                break
print(max(score)) # 최대값 출력



리스트의 인덱스에 눈금을 저장하는 방식으로 점수를 계산 했다.

새롭게 알게 된 사실 1) list.index('호출할 요소(값)', 인덱스a, 인덱스b):
이렇게 함수를 사용하면 인덱스 a 이상, b 이하에서 호출할 값을 가진 위치 중 가장 작은 수를 반환한다. 

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

728x90