[C/Cpp] BOJ 2525번: 주사위 세개

ㅎㅎ·2023년 1월 16일
0

BOJ

목록 보기
9/65

BOJ 2525번: 주사위 세개

문제

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개의 눈이 빈칸을 사이에 두고 각각 주어진다.

출력

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


⭕ 풀이 코드 - 성공

#include <iostream>

using namespace std;

int main()
{
    int a, b, c, reward=0;
    cin >> a >> b >> c;
    
    if(a == b && b == c) { // 같은 눈이 3개 : 10,000 + 같은눈*1,000
        reward = 10000 + a*1000;
    }
    else if(a == b) { // 같은 눈이 2개 : 1,000 + 같은눈*100
        reward = 1000 + a*100;
    }
    else if(a == c) {
        reward = 1000 + a*100;
    }
    else if(b == c) {
        reward = 1000 + b*100;
    }
    else { // 모두 다른 경우 : 그중가장큰눈*100
        if(a > b) {
            if(a > c) { // a가 제일 클 때
                reward = a * 100;
            }
        }
        else if (b > c) { // b가 제일 클 때
            reward = b * 100;
        }
        
        if(c > a) { 
            if(c > b) { // C가 제일 클 때
                reward = c * 100;   
            }
        }
    }
    
    cout << reward << endl;
    
    return 0;
}

if문을 너무 많이 사용한 것 같다고 생각해서 더 줄일 수 있는 방법을 찾아보았다.

👍 개선된 코드 (Cpp)

max() 함수가 C++엔 있구나... 짱이다... C언어에는 없는데...

#include <iostream>
using namespace std;

int main()
{
    int a, b, c, reward=0;
    cin >> a >> b >> c;
    
    if(a == b && b == c) { // 같은 눈이 3개 : 10,000 + 같은눈*1,000
        reward = 10000 + a*1000;
    }
    else if(a == b || a == c) { // 같은 눈이 2개 : 1,000 + 같은눈*100
        reward = 1000 + a*100;
    }
    else if(b == c) {
        reward = 1000 + b*100;
    }
    else { // 모두 다른 경우 : 그중가장큰눈*100
        reward = max(a, max(b, c)) * 100;
    }
    
    cout << reward << endl;
    return 0;
}

👍 개선된 코드 (C)

하지만~ max() 함수가 없는 C에서도 if문 정리는 더 할 수 있다.

#include <stdio.h>

int main() {
    int a, b, c, reward=0;
    scanf("%d %d %d", &a, &b, &c);

    if(a == b && b == c) { // 같은 눈이 3개 : 10,000 + 같은눈*1,000
        reward = 10000 + a*1000;
    }
    else if(a == b || a == c) { // 같은 눈이 2개 : 1,000 + 같은눈*100
        reward = 1000 + a*100;
    }
    else if(b == c) {
        reward = 1000 + b*100;
    }
    else { // 모두 다른 경우 : 그중가장큰눈*100
        int max = a;
        if (b > max) max = b;
        if (c > max) max = c;
        reward = max * 100;
    }
    printf("%d\n", reward);
    return 0;
}

변수를 적게 쓰는 것에 지나치게 집착한 나머지 가독성을 떨어트렸었던 것 같다. max 변수를 새로 할당해서 최댓값을 구하는 코드를 작성하면 훨씬 간결한 코드가 만들어진다.

profile
Backend

0개의 댓글