1 분 소요

1. 문제Permalink

[Bronze IV] 주사위 세개 - 2480Permalink

문제 링크

성능 요약Permalink

메모리: 30864 KB, 시간: 72 ms

분류Permalink

사칙연산(arithmetic), 수학(math)

문제 설명Permalink

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.

  1. 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
  2. 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
  3. 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

입력Permalink

첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.

출력Permalink

첫째 줄에 게임의 상금을 출력 한다.

출처: 백준, https://https://www.acmicpc.net/

2. 해결방법 시간복잡도Permalink

  1. 단순 코딩 O(1)

3. 문제 해결 및 코드Permalink


A, B, C = map(int, input().split())
cost = 0
if A == B == C:
cost += 10000 + (A * 1000)
elif A == B or A == C:
cost += 1000 + (A * 100)
elif B == C:
cost += 1000 + (B * 100)
else:
if A > B and A > C:
cost += (A * 100)
elif B > C and B > A:
cost += (B * 100)
else:
cost += (C * 100)
print(cost)
view raw 2480.py hosted with ❤ by GitHub
  • 주석을 참고하면서 이해를 돕습니다.Permalink

4. 알고리즘 및 해설Permalink

  1. 3개의 값을 받은 이후 해당 값을 if문을 통해 경우의 수를 계산하여 맞는 값을 출력한다.
    • 3개의 눈이 같은 경우
    • 2개의 눈이 같은 경우
    • 모두 다른 경우
      • A의 눈이 가장 큰 경우
      • B의 눈이 가장 큰 경우
      • C의 눈이 가장 큰 경우
  2. 이후 해당 값을 출력해준다.