꾸준히 안타치기
2476 - 주사위게임 / 2480 - 주사위 세개 본문
1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
- 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
- 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
- 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.
입력
첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
예제 입력 1 복사
3
3 3 6
2 2 2
6 2 5
예제 출력 1 복사
12000
풀이
n = int(input())
res = 0
for i in range(n):
tmp = input().split()
tmp.sort()
a, b, c = map(int, tmp)
if a == b and b == c:
money = 10000+a * 1000
elif a == b or a == c:
money = 1000 + a * 100
elif b == c:
money = 1000 + b * 100
else:
money = c * 100
if money > res:
res = money
print(res)
n = int(input()) #테스트케이스입력받기
res = 0 #결과값 저장할 변수
for i in range(n):#n개만큼 반복해 문자열을 받음
tmp = input().split() #tmp에 띄어쓰기 기준으로 담고
tmp.sort()#오름차순정렬
a, b, c = map(int, tmp) #a,b,c에 각각 담는데 tmp리스트에 담긴 내용을 정수화함
if a == b and b == c: #세수가 모두 같은 수가 나왔을때
money = 10000+a * 1000
elif a == b or a == c: #2개의 수가 같은수가 나올경우
money = 1000 + a * 100
elif b == c: #2개의 수가 같은수가 나올경우
money = 1000 + b * 100
else: #1개의 수가 같은수가 나올경우
money = c * 100
if money > res: #결과돈이 res보다 크다면 res에 돈을 담는다.
res = money
print(res) #res출력
경우의수 체크 ,띄어쓰기를 주의하자.
2480 - 주사위 세개
문제
1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
- 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
- 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
- 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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원을 상금으로 받게 된다.
3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
입력
첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력
첫째 줄에 게임의 상금을 출력 한다.
예제 입력 1
3 3 6
예제 출력 1
1300
풀이
a,b,c = map(int, input().split())
if a == b and b == c :
print(10000 + a * 1000)
elif a == b or a == c :
print(1000 + a * 100)
elif b == c :
print(1000 + b*100)
else :
print(max(a,b,c) * 100)
max 함수 —→ , a,b,c중 가장 큰것
'CS > 백준' 카테고리의 다른 글
14426. 접두사 찾기 💭 (list, startwith()함수사용) (0) | 2022.07.18 |
---|---|
1935. 후위 표기식2 (stack) (0) | 2022.07.14 |
2346 - 풍선 터뜨리기 💭 (0) | 2022.07.13 |
1835 - 카드(deque) 💭 (0) | 2022.07.12 |
2164 - 카드2 ( queue, deque ) (0) | 2022.07.12 |