아무코딩

[프로그래머스 level2] 조이스틱 본문

알고리즘/프로그래머스

[프로그래머스 level2] 조이스틱

동 코 2020. 4. 4. 21:35

문제풀이

 

그리디 문제이다. 문제 lv2 문제였지만 나름 시간을 쓴 거 같다. 

마지막 테스트 케이스 때문에 코드를 전면 수정하였다.

한경로로 쭉 직진하는 거만 생각했는데 갔다 돌아오는 경우도 고려했어야되서

현재 코드처럼 수정하였다.

 

소스코드

더보기
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
48
49
50
51
52
53
#include <string>
#include <vector>
#include <algorithm>
#include <iostream>
using namespace std;
 
vector<int> counts;
int total_cnt = 0;
int solution(string name) {
    int result = 0;
    for (int i = 0; i < name.size(); i++) {
        int cnt = min(name[i] - 'A''Z' - name[i] + 1);
        counts.push_back(cnt);
        total_cnt += cnt;
    }
    int idx = 0;
    while (1) {
        
        result += counts[idx];
        //cout << idx <<","<<result<< endl;
        total_cnt -= counts[idx];
        counts[idx] = 0;
        if (total_cnt == 0)
            break;
        int left_cnt = 0;
        int right_cnt = 0;
        int left_idx = idx;
        int right_idx = idx;
        int n = name.size();
        while (counts[left_idx] <= 0) {
            left_cnt++;
            left_idx--;
            left_idx = (left_idx < 0) ? n - 1 : left_idx;
        }
        while (counts[right_idx]<=0) {
            right_cnt++;
            right_idx = (right_idx + 1) % n;
        }
        if (left_cnt < right_cnt) {
            result += left_cnt;
            idx = left_idx;
        }
        else {
            result += right_cnt;
            idx = right_idx;
        }
    }
    return result;
}
 
int main() {
    cout << solution("BBAABB"<< endl;
}
 

 

문제 링크 : https://programmers.co.kr/learn/courses/30/lessons/42860

 

프로그래머스

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

programmers.co.kr

 

Comments