728x90

문제

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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

 

입력

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

 

출력

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

 

예제 입력 1 

3 3 6

 

예제 출력 1

1300

 

예제 입력 2 

2 2 2

 

예제 출력 2 

12000

 

예제 입력 3 

6 2 5

 

예제 출력 3

600

 

출처

Olympiad > 한국정보올림피아드 > 한국정보올림피아드시․도지역본선 > 지역본선 2010 > 중등부 1번

  • 잘못된 데이터를 찾은 사람: sait2000
  • 데이터를 추가한 사람: tkdring3

 

알고리즘 분류

  • 수학
  • 사칙연산

 

문제 출처

https://www.acmicpc.net/problem/2480

 

2480번: 주사위 세개

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.  같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.  같은 눈이 2개

www.acmicpc.net

 


 

문제 해결 방법

  • for 문을 이용하여 입력받은 주사위의 눈의 값이 담길 배열(dice)에 하나씩 값을 넣었다.
    • 값을 넣으면서 최댓값을 max 변수에 할당한다.
    • 이 최댓값은 문제의 규칙3을 만족하기 위해 사용된다.
  • if 문을 이용하여 배열에 담긴 값들을 서로 비교하여, 문제의 규칙에 맞는 값이 출력되도록 하여 문제를 해결하였다.

 

코드

#include <iostream>
using namespace std;

int main() {
    cin.tie(NULL);
    cout.tie(NULL);
    ios_base::sync_with_stdio(false);

    int dice[3], max = 0, prize;

    for (int i = 0; i < 3; i++) {
        cin >> dice[i];
        if (max < dice[i]) {    
            max = dice[i];      // find the max value.
        }
    }

    if (dice[0] == dice[1]) {
        if (dice[1] == dice[2]) {
            prize = 10000 + dice[0] * 1000;
        }
        else {
            prize = 1000 + dice[0] * 100;
        }
    }
    else if (dice[1] == dice[2]) {
        if (dice[0] == dice[1]) {
            prize = 10000 + dice[1] * 1000;
        }
        else {
            prize = 1000 + dice[1] * 100;
        }
    }
    else if (dice[0] == dice[2]) {
        if (dice[1] == dice[2]) {
            prize = 10000 + dice[0] * 1000;
        }
        else {
            prize = 1000 + dice[0] * 100;
        }
    }
    else {
        prize = max * 100;
    }
    
    cout << prize << endl;

    return 0;
}

 

채점 결과

 

참고

  • [단계별로 풀어보기] > [조건문]

 

728x90

'Problem Solving > BOJ' 카테고리의 다른 글

[BOJ-15552][C++] 빠른 A+B  (0) 2022.07.09
[BOJ-8393][C++] 합  (0) 2022.07.09
[BOJ-10950][C++] A+B - 3  (0) 2022.07.09
[BOJ-2739][C++] 구구단  (0) 2022.07.09
[BOJ-2525][C++] 오븐 시계  (0) 2022.07.08
[BOJ-2884][C++] 알람 시계  (0) 2022.07.08
[BOJ-14681][C++] 사분면 고르기  (0) 2022.07.08
[BOJ-2753][C++] 윤년  (0) 2022.07.08