728x90

2023.06.29 문제 풀이 결과 : 오답

 

 

문제

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>
#include<cstdlib>
int main()
{

    int sum = 0;
    int result[3];
    std::cin >> result[0] >> result[1] >> result[2];


    if (result[0] == result[1] && result[1] == result[2])
    {
        sum += 10000 + (result[0] * 1000);
    }
    else if(result[0] == result[1] || result[0] == result[2] || result[1] == result[2])
    {
        if (result[0] == result[1] || result[0] == result[2])
            sum += 1000 + (result[0] * 100);
        else if (result[1] == result[2])
            sum += 1000 + (result[1] * 100);
    }
    else
    {
        int maxValue = 0;
        for (int i = 0; i < sizeof(result); i++)
        {
            if (maxValue < result[i])
                maxValue;
        }
        sum += maxValue * 100;
    }
    std::cout << sum << std::endl;


}

 

GPT의 풀이

#include <iostream>
#include <algorithm>

using namespace std;

int main() {
    int dice[3];
    for (int i = 0; i < 3; i++) {
        cin >> dice[i];
    }

    sort(dice, dice + 3);  // 주사위 눈을 오름차순으로 정렬

    int prize;
    if (dice[0] == dice[2]) {
        // 같은 눈이 3개인 경우
        prize = 10000 + dice[0] * 1000;
    } else if (dice[0] == dice[1] || dice[1] == dice[2]) {
        // 같은 눈이 2개인 경우
        prize = 1000 + dice[1] * 100;
    } else {
        // 모두 다른 눈인 경우
        prize = dice[2] * 100;
    }

    cout << prize << endl;

    return 0;
}

오답 원인 분석

   sort(dice, dice + 3);  // 주사위 눈을 오름차순으로 정렬

정답의 핵심은 배열의 요소를 오름차순으로 정렬을 하고 
가장 작은 요소와 큰 요소가 같으면 같은 눈이 3개라고 판단하였다.

 

반면 내가 작성한 코드는

데이터를 정렬하지않고 배열에있는 요소 하나하나 모두 비교하였다.

 

다음과 같은 방법을 사용한다면 배열의 요소가 1개만 늘어도 조건문을 기하급수적으로 추가해야한다는 문제점이 있다.

 

728x90

+ Recent posts