Posts [알고리즘] 프로그래머스 - [1차] 다트 게임
Post
Cancel

[알고리즘] 프로그래머스 - [1차] 다트 게임


문제

[1차]다트게임


접근

점수 중에 10점도 있기 때문에 이러한 경우를 한번 전처리하면서 걸러주었다.
10점을 묶어서 저장하기 위해 리스트로 바꿔서 저장해두고, 해당 리스트를 이용해 점수를 계산했다.
전처리하는 부분에서 i+1이 범위를 넘어갈까봐 체크하는 부분을 두었는데, 생각해보니 점수가 가장 마지막에 오는 경우는 없다. (점수와 보너스는 항상 있기 때문)
옵션 중 이전 점수와 현재 점수를 두 배하는 부분을 쉽게 처리하기 위해 score 배열은 인덱스를 1부터 시작하도록 생각했다.
C++의 경우 숫자인지 판별하기가 귀찮아서 그냥 모든 경우가 아닌 경우 숫자인 것으로 처리했다.

코드

  • 파이썬 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
def solution(dartResult):
    score = [0,0,0,0]
    bonus = {'S':1, 'D':2, 'T':3}
    cnt = 1
    dartList = []
    tenFlag = False
    for i in range(len(dartResult)):
        if dartResult[i] == '1' and i+1 < len(dartResult):
            if dartResult[i+1] == '0':
                tenFlag = True
                dartList.append('10')
                continue
        if dartResult[i] == '0' and tenFlag:
            tenFlag = False
            continue
        dartList.append(dartResult[i])

    for item in dartList:
        if item.isdecimal():
            score[cnt] = int(item)
            cnt+=1
        elif bonus.get(item, 0):
            score[cnt-1] = score[cnt-1] ** bonus[item]
        else:
            if item == '*':
                score[cnt-1] *= 2
                score[cnt-2] *= 2
            else:
                score[cnt-1] *= -1

    answer = score[1] + score[2] + score[3]
    return answer
  • C++ 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#include <string>
#include <vector>
using namespace std;

int solution(string dartResult) {
    int answer = 0;
    int score[4] = {0};
    int cnt = 0;
    vector<string> dart;
    bool tenFlag = false;
    for(int i = 0; i< dartResult.size(); i++){
        if(dartResult[i] == '1' && dartResult[i+1] == '0'){
            tenFlag = true;
            dart.push_back("10");
            continue;
        }
        else if(dartResult[i] == '0' && tenFlag){
            tenFlag = false;
            continue;
        }
        dart.push_back(dartResult.substr(i,1));
    }
    for(int i = 0; i<dart.size(); i++){
        if(dart[i] == "S"){
            continue;
        }
        else if(dart[i] == "D"){
            score[cnt] *= score[cnt];
        }
        else if(dart[i] == "T"){
            score[cnt] *= score[cnt] * score[cnt];
        }
        else if(dart[i] == "*"){
            score[cnt] *= 2;
            score[cnt-1] *= 2;
        }
        else if(dart[i] == "#"){
            score[cnt] *= -1;
        }
        else{
            cnt++;
            score[cnt] = stoi(dart[i]);
        }
    }
    answer = score[1]+score[2]+score[3];
    return answer;
}


This post is licensed under CC BY 4.0 by the author.

[알고리즘] 프로그래머스 - 정수 내림차순으로 배치하기

[알고리즘] 프로그래머스 - 실패율