백준 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
풀이 과정
첫 번째 풀이는 주사위 눈을 리스트로 담고, 정렬한 후에 주사위 각각을 전부 비교했다.
두 번째 풀이는 주사위 눈을 정렬한 후에 담고, 집합을 이용했다.
주사위 눈 리스트를 집합으로 만든 후 길이가 1이면 전부 같다는 뜻이다.
길이가 2일 때, 인덱스 1, 2인 눈이 서로 같다면 주사위 눈 3개가 같다는 뜻이다.
길이가 2일 때, 인덱스 1, 2인 눈이 다르다면 주사위 눈이 2개씩 같다는 뜻이다.
길이가 3일 때, 인접한 두 눈이 같은지 세 번 반복해 찾는다.
길이가 4라면 맨 마지막 눈을 찾는다.
코드 1
N = int(input())
prize = []
for _ in range(N):
dice = list(map(int, input().split()))
dice.sort()
tmp = 0
if dice[0] == dice[1] == dice[2] == dice[3]:
tmp = 50000 + dice[0] * 5000
elif dice[0] == dice[1] == dice[2]:
tmp = 10000 + dice[0] * 1000
elif dice[1] == dice[2] == dice[3]:
tmp = 10000 + dice[1] * 1000
elif dice[0] == dice[1] and dice[2] == dice[3]:
tmp = 2000 + dice[0] * 500 + dice[2] * 500
elif dice[0] == dice[1]:
tmp = 1000 + dice[0] * 100
elif dice[1] == dice[2]:
tmp = 1000 + dice[1] * 100
elif dice[2] == dice[3]:
tmp = 1000 + dice[2] * 100
else:
tmp = dice[3] * 100
prize.append(tmp)
result = max(prize)
print(result)
코드 2
N = int(input())
prize = []
for _ in range(N):
dice = sorted(list(map(int, input().split())))
tmp = 0
if len(set(dice)) == 1:
tmp = 50000 + dice[0] * 5000
elif len(set(dice)) == 2:
if dice[1] == dice[2]:
tmp = 10000 + dice[1] * 1000
else:
tmp = 2000 + (dice[1] + dice[2]) * 500
elif len(set(dice)) == 3:
for i in range(3):
if dice[i] == dice[i + 1]:
tmp = 1000 + dice[i] * 100
else:
tmp = dice[-1] * 100
prize.append(tmp)
result = max(prize)
print(result)
Author And Source
이 문제에 관하여(백준 2484 주사위 네개), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@mynote/백준-2484-주사위-네개저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)