본문 바로가기
코딩테스트/백준

[C++/연결리스트] BOJ 5397 키로거

by Ssubini 2021. 6. 10.

https://www.acmicpc.net/problem/5397

 

5397번: 키로거

첫째 줄에 테스트 케이스의 개수가 주어진다. 각 테스트 케이스는 한줄로 이루어져 있고, 강산이가 입력한 순서대로 길이가 L인 문자열이 주어진다. (1 ≤ L의 길이 ≤ 1,000,000) 강산이가 백스페이

www.acmicpc.net

 

 

#include <iostream>
#include <list>
#include <string>

using namespace std;

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

    int n;
    list<char> pw;
    list<char>::iterator iter;
    string inputpw;

    cin >> n;

    while(n--){
        cin >> inputpw;
        iter = pw.begin();
        for(auto a : inputpw){
            if(a == '<'){
                if(iter != pw.begin()) iter--;
            }else if(a == '>'){
                if(iter != pw.end()) iter++;
            }else if(a == '-'){
                if(iter != pw.begin()) iter = pw.erase(--iter);
            }else pw.insert(iter,a);
        }

        for(iter = pw.begin(); iter != pw.end(); iter++) cout << *iter;
        cout << "\n";
        pw.clear();
    }
    
}

 

해결은 했지만 이게 맞나 싶다...

마지막 리스트 clear 안해놓고 이상하네... 하고 쳐다보는 바보같은 짓도 잠깐 했다

 

스택으로 많이들 풀던데 담에 해볼게요...

'코딩테스트 > 백준' 카테고리의 다른 글

[C++/덱] BOJ 5430 AC  (0) 2021.06.22
[C++/큐] BOJ 2164 카드2  (0) 2021.06.15
[C++/큐] BOJ 10845 큐  (0) 2021.06.15
[C++/스택] BOJ 10773 제로  (0) 2021.06.11
[C++/스택] BOJ 10828 스택  (0) 2021.06.11

댓글