본문 바로가기

Algorithm

2018 KAKAO BLIND RECRUITMENT[1차] 다트 게임

반응형

https://programmers.co.kr/learn/courses/30/lessons/17682

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

스택을 이용해서 간단히 풀었음. 단지 10일 때 0 중복 예외만 신경써주면 됨.

 

#include<iostream>
#include <string>
#include<stack>
using namespace std;

int solution(string dartResult) {
    int answer = 0;
    
    
    stack<int> sta;
    for(int i = 0; i < dartResult.size(); i++)
    {
        if(i < dartResult.size() -1 && dartResult[i] == '1'  && dartResult[i+1] == '0')
        {
            sta.push(10);
            i++;
        }
        else if(dartResult[i] >= '0' && dartResult[i] <= '9')
        {
            sta.push(dartResult[i] -'0');
        }
        else if(dartResult[i] == 'D')
        {
            int num = sta.top();
            sta.pop();
            sta.push(num*num);
        }
        else if(dartResult[i] == 'T')
        {
            int num = sta.top();
            sta.pop();
            sta.push(num*num*num);
        }
        else if(dartResult[i] == '*')
        {
            if(sta.size() >= 2)
            {
                int num1 = sta.top()*2;
                sta.pop();
                int num2 = sta.top()*2;
                sta.pop();
                sta.push(num2);
                sta.push(num1);
                
            }
            else if(sta.size() == 1)
            {
                int num = sta.top()*2;
                sta.pop();
                sta.push(num);
            }
        }
        else if(dartResult[i] == '#')
        {
            int num = sta.top();
            sta.pop();
            sta.push(num*(-1));
            
        }
    }
    
    while(!sta.empty())
    {
        answer += sta.top();
        sta.pop();
    }
    
    return answer;
}
반응형