[백준] 2480번 주사위 세 개 / Python

이희령·2024년 3월 23일
0

알고리즘

목록 보기
6/20
post-thumbnail

문제

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 3 61300
2 2 212000
6 2 5600

나의 풀이

first, second, third = map(int, input().split())
[a, b, c] = sorted([first, second, third])

if a == b and b == c:
   print(10000 + (a * 1000))
elif a == b or b == c:
    print(1000 + (b * 100))
else:
    print(c * 100)
  • 3개의 주사위 눈이 모두 다른 경우에 그 중 가장 큰 눈을 구하기 위해서 sorted()를 사용했다.

다른 사람의 풀이

a, b, c = map(int,input().split())

if a == 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()를 이용해서 최댓값을 구했다.
  • 내 풀이에서는 3개의 눈이 모두 다른 경우 이외에도 sorted() 함수로 배열을 정렬하는 불필요한 연산이 들어가기 때문에 max()를 이용하는 게 더 효율적인 풀이가 될 거 같다.
  • 출처: [백준 2480 파이썬] - 주사위 세개
profile
Small Steps make a Big Difference.🚶🏻‍♀️

0개의 댓글