키로거
입력 케이스는 캐릭터와 좌우 화살표, 백스페이스로 분류된다.
캐릭터를 제외한 추가 키 들에 대한 기능을 정의해야 하는데,
좌우 화살표의 입력은 문자열 자체를 변경하진 않고 캐릭터가 입력될 위치(커서)를 바꾼다.
백스페이스는 현재 커서 바로 앞의 캐릭터를 지워야 한다.
위와 같은 기능을 구현하기 위해,
커서의 앞뒤를 구분하면서, 부가 키의 입력 시에 빠른 결과를 리턴해줄 구조를 짜야 하는데,
이를 스택으로 구현한다면 선형시간에 모든 기능이 수행된다.
커서의 앞과 뒤를 두 개의 스택으로 생각한다면
캐릭터의 입력은 앞의 스택에 push,
왼쪽 화살표는 앞 스택에서 pop -> 뒤 스택에 push,
반대로 오른쪽 화살표는 뒤 스택에서 pop -> 앞 스택에 push,
백스페이스는 앞 스택에서 pop
으로 구현할 수 있다.
기타 예외처리를 추가한 코드는 다음과 같다.
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 54 55 56 57 58 59 60 61 62 63 64 65 66 | #include <stdio.h> int T; char buf[1000001]; int len; int strlen(char buf[]) { int cnt = 0; while (buf[cnt] != '\0') cnt++; return cnt; } char stack1[1000001]; char stack2[1000001]; int stack1_size; int stack2_size; void stack_push(char stack[], char c, int& size) { stack[size++] = c; } char stack_pop(char stack[], int& size) { return stack[--size]; } int main() { scanf("%d", &T); while (T--) { scanf("%s", buf); len = strlen(buf); for (int i = 0; i < len; ++i) { if (buf[i] == '<') { if (stack1_size == 0) continue; stack_push(stack2, stack_pop(stack1, stack1_size), stack2_size); } else if (buf[i] == '>') { if (stack2_size == 0) continue; stack_push(stack1, stack_pop(stack2, stack2_size), stack1_size); } else if (buf[i] == '-') { if (stack1_size == 0) continue; stack_pop(stack1, stack1_size); } else stack_push(stack1, buf[i], stack1_size); } for (int i = 0; i < stack1_size; ++i) printf("%c", stack1[i]); for (int i = stack2_size-1; i >= 0; --i) printf("%c", stack2[i]); putchar('\n'); stack1_size = 0; stack2_size = 0; } return 0; } | cs |
'알고리즘 > 미분류' 카테고리의 다른 글
백준) 3986 좋은 단어 (0) | 2018.01.22 |
---|---|
백준) 9935 문자열 폭발 (스택) (0) | 2018.01.22 |
백준) 11559 Puyo Puyo (0) | 2018.01.14 |
백준) 2110 공유기 설치 (0) | 2018.01.09 |
백준) 1695 팰린드롬 만들기 (0) | 2017.09.06 |