일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 스택
- 2020.06.14
- Reversing
- class
- Reverse Engineering
- 백준 10828
- Constraint
- scroll
- 2020.05.17
- 순차 컨테이너
- UIPanGestureRecognizer
- SWiFT
- stl
- 알고리즘
- 컴퓨터구조
- ios
- 표준 템플릿 라이브러리
- vector
- UIView
- 백준 1920
- Animation
- BOJ
- struct
- NavigationBar
- Stack
- list
- Swing
- 2020.04.19
- 모달인듯 모달 아닌 뷰
- 컴퓨터 구조
- Today
- Total
야금야금
1-2. 기초 자료구조 (1)_#1406 에디터 [C/C++] 본문
문제
한 줄로 된 간단한 에디터를 구현하려고 한다. 이 편집기는 영어 소문자만을 기록할 수 있는 편집기로, 최대 600,000글자까지 입력할 수 있다.
이 편집기에는 '커서'라는 것이 있는데, 커서는 문장의 맨 앞(첫 번째 문자의 왼쪽), 문장의 맨 뒤(마지막 문자의 오른쪽), 또는 문장 중간 임의의 곳(모든 연속된 두 문자 사이)에 위치할 수 있다. 즉 길이가 L인 문자열이 현재 편집기에 입력되어 있으면, 커서가 위치할 수 있는 곳은 L+1가지 경우가 있다.
이 편집기가 지원하는 명령어는 다음과 같다.
L | 커서를 왼쪽으로 한 칸 옮김 (커서가 문장의 맨 앞이면 무시됨) |
D | 커서를 오른쪽으로 한 칸 옮김 (커서가 문장의 맨 뒤이면 무시됨) |
B | 커서 왼쪽에 있는 문자를 삭제함 (커서가 문장의 맨 앞이면 무시됨) 삭제로 인해 커서는 한 칸 왼쪽으로 이동한 것처럼 나타나지만, 실제로 커서의 오른쪽에 있던 문자는 그대로임 |
P$ | $라는 문자를 커서 왼쪽에 추가함 |
초기에 편집기에 입력되어 있는 문자열이 주어지고, 그 이후 입력한 명령어가 차례로 주어졌을 때, 모든 명령어를 수행하고 난 후 편집기에 입력되어 있는 문자열을 구하는 프로그램을 작성하시오. 단, 명령어가 수행되기 전에 커서는 문장의 맨 뒤에 위치하고 있다고 한다.
입력
첫째 줄에는 초기에 편집기에 입력되어 있는 문자열이 주어진다. 이 문자열은 길이가 N이고, 영어 소문자로만 이루어져 있으며, 길이는 100,000을 넘지 않는다. 둘째 줄에는 입력할 명령어의 개수를 나타내는 정수 M(1 ≤ M ≤ 500,000)이 주어진다. 셋째 줄부터 M개의 줄에 걸쳐 입력할 명령어가 순서대로 주어진다. 명령어는 위의 네 가지 중 하나의 형태로만 주어진다.
출력
첫째 줄에 모든 명령어를 수행하고 난 후 편집기에 입력되어 있는 문자열을 출력한다.
정리
BOJ길라잡이를 따라 vector을 처음 공부하고 신나서 vector로 본 문제를 풀었다가 시간 초과가 떴다.
문제는 어렵지 않았는데 iterator개념과 erase()쓰는게 헷갈렸던 문제
다시 보기
list<char> editor(input.begin(), input.end()); : 다른 컨테이너로부터 초기값의 범위를 받아 리스트 생성
cursor = editor.erase(--cursor);
: 커서의 위치를 한 칸 왼쪽으로 옮기고 해당 문자(커서 오른쪽) 삭제 후 다음 iterator값으로
for(cursor=editor.begin(); cursor!=editor.end(); cursor++) cout<<*cursor; : 반복문 사용법
코드
#include <iostream>
#include <list>
using namespace std;
int main() {
string input;
cin >> input;
list<char> editor(input.begin(), input.end()); //다른 컨테이너로부터 초기값의 범위를 받아 생성
list<char>::iterator cursor = editor.end();
int m;
cin >> m;
string cmd;
while (m--)
{
cin >> cmd;
if (cmd == "L" && cursor != editor.begin()) cursor--;
else if (cmd == "D" && cursor != editor.end()) cursor++;
else if (cmd == "B" && cursor != editor.begin()) {
cursor = editor.erase(--cursor);
}
else if (cmd == "P") {
char x;
cin >> x;
editor.insert(cursor, x);
}
cmd = "";
}
for (cursor = editor.begin(); cursor != editor.end(); cursor++)
cout << *cursor;
}
'Algorithm > BOJ' 카테고리의 다른 글
1-2. 기초 자료구조 (1)_#10845 큐 [C/C++] (0) | 2021.04.01 |
---|---|
1-2. 기초 자료구조 (1)_#10828 스택 [C/C++] (0) | 2021.04.01 |
1-1. 탐색과 정렬 (1)_#1920 수 찾기 [C/C++] (0) | 2021.03.29 |