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 6 | 1300 |
2 2 2 | 12000 |
6 2 5 | 600 |
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)
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()
를 이용해서 최댓값을 구했다.sorted()
함수로 배열을 정렬하는 불필요한 연산이 들어가기 때문에 max()
를 이용하는 게 더 효율적인 풀이가 될 거 같다.