[C++] 소프티어(Softeer) 8단 변속기

문제설명

현대자동차에서는 부드럽고 빠른 변속이 가능한 8단 습식 DCT 변속기를 개발하여 N라인 고성능차에 적용하였다. 관련하여 SW 엔지니어인 당신에게 연속적으로 변속이 가능한지 점검할 수 있는 프로그램을 만들라는 임무가 내려왔다.

당신은 변속기가 1단에서 8단으로 연속적으로 변속을 한다면 ascending, 8단에서 1단으로 연속적으로 변속한다면 descending, 둘다 아니라면 mixed 라고 정의했다.

변속한 순서가 주어졌을 때 이것이 ascending인지, descending인지, 아니면 mixed인지 출력하는 프로그램을 작성하시오.


제약조건

주어지는 숫자는 문제 설명에서 설명한 변속 정도이며, 1부터 8까지 숫자가 한번씩 등장한다.


입력형식

첫째 줄에 8개 숫자가 주어진다.


출력형식

첫째 줄에 ascending, descending, mixed 중 하나를 출력한다.


풀이

입력된 값을 순서대로 비교하여 1씩 증감하는지 판단하는 로직을 구현하여 문제를 풀었습니다.

#include<iostream>
#include<vector>

using namespace std;

int main(int argc, char** argv)
{
    vector<int> arr;
    string answer = "";

    for (int i = 0; i < 8; i++)
    {
        int n;
        cin >> n;
        arr.push_back(n);
    }

    bool is_asc = false;

    for (int i = 0; i < 7; i++)
    {
        if (i == 0)
        {
            if ((arr[i] + 1) == arr[i + 1])
            {
                is_asc = true;
                continue;
            }
            else if ((arr[i] - 1) == arr[i + 1])
            {
                is_asc = false;
                continue;
            }
            else
            {
                answer = "mixed";
                break;
            }
        }

        if (is_asc)
        {
            if ((arr[i] + 1) == arr[i + 1])
            {
                continue;
            }
            else
            {
                answer = "mixed";
                break;
            }
        }
        else
        {
            if (arr[i] - 1 == arr[i + 1])
            {
                continue;
            }
            else
            {
                answer = "mixed";
                break;
            }
        }
    }

    if (answer != "mixed")
    {
        if (is_asc)
            answer = "ascending";
        else
            answer = "descending";
    }

    cout << answer;

    return 0;
}


결과

코드 실행결과

Categories:

Updated:

Leave a comment