알고리즘/알고리즘 문제 풀이

(C++) 백준 1406번 - 에디터

용꿀 2023. 3. 16. 17:05

문제 링크 : https://www.acmicpc.net/problem/1406

 

1406번: 에디터

첫째 줄에는 초기에 편집기에 입력되어 있는 문자열이 주어진다. 이 문자열은 길이가 N이고, 영어 소문자로만 이루어져 있으며, 길이는 100,000을 넘지 않는다. 둘째 줄에는 입력할 명령어의 개수

www.acmicpc.net

풀이

C++의 STL List 라이브러리를 사용하여 풀이하였다. 연결 리스트로 풀면 실버2 문제치곤 어렵지 않게 해결할 수 있다.

백준 5397번 키로그와 거의 동일한 문제여서 동일하게 풀이를 하면 된다.

#include <iostream>
#include <list>

using namespace std;

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);

    string s;
    cin >> s;
    list<char> L;
    for (auto c : s) L.push_back(c);
    auto cursor = L.end(); // 제일 오른쪽으로 cur 두기
    int q;
    cin >> q;
    while (q--) {
        char op;
        cin >> op;
        if (op == 'P') {
            char add;
            cin >> add;
            L.insert(cursor, add);
        }
        else if (op == 'L') {
            if (cursor != L.begin()) cursor--; // 제일 왼쪽이면 해당 명령 무시
        }
        else if (op == 'D') {
            if (cursor != L.end()) cursor++; // 제일 오른쪽이면 해당 명령 무시
        }
        else {
            if (cursor != L.begin()) { // 제일 왼쪽이면 해당 명령 무시
                cursor--; // 커서 위치의 왼쪽 글자를 삭제하기 위해 이동
                L.erase(cursor++); // 삭제 후 원위치로
            }
        }
    }
    for (auto c : L) cout << c;
}