본문 바로가기
알고리즘/백준

[백준 1360] 되돌리기 (C++)

by fortissimo 2024. 5. 10.

문제


민식이는 다음과 같이 두 개의 명령만 지원하는 새로운 텍스트 에디터를 만들었다.

  • “type c" : 현재 글의 가장 뒤에 문자 c를 추가한다.
  • “undo t" : 이전 t초동안 수행된 작업을 역순으로 되돌린다.

처음 텍스트 에디터는 비어있다.

예를 들어, 다음과 같은 명령을 진행했다고 하자.

  • 1초 : type a
  • 2초 : type b
  • 3초 : type c
  • 5초 : undo 3

3초가 끝날 때, 텍스트는 "abc"이다. 5초때, 이전 3초동안 한 작업을 역순으로 되돌려야 한다. c는 지워지고, b도 지워질 것이다. 따라서 a만 남는다.

되돌리기가 되돌리기 될 수도 있다.

예를 들어

  • 1초 : type a
  • 2초 : type b
  • 3초 : undo 2
  • 4초 : undo 2

2초일 때, 텍스트는 “ab"이다. 3초때 모든 것이 되돌리기 되므로 텍스트는 빈 텍스트가 되고, 4초때 3초때 되돌리기 한 것이 되돌리기 되고, 2초때 type b한 것이 지워진다. 따라서 텍스트는 ”a"가 된다.

명령과 수행한 시간이 주어질 때, 마지막에 남은 텍스트를 구하는 프로그램을 작성하시오.

 

입력


첫째 줄에 명령의 개수 N이 주어진다. 둘째 줄부터 N개의 줄에 명령과 수행한 시간이 주어진다. 항상 시간이 오름차순으로 주어지고, type c에서 c는 알파벳 소문자, undo t에서 t는 1보다 크거나 같고 109보다 작거나 같은 자연수이다. N은 50보다 작거나 같은 자연수이다.

 

출력


첫째 줄에 모든 명령을 수행한 후에 남아있는 텍스트를 출력한다.

 

문제 풀이


구현 문제.

벡터에 각 시간마다의 문자열을 push하여 모든 명령이 완료되면 맨 마지막으로 얻은 명령을 출력한다.

명령이 type이라면 이전 문자열에 c를 붙이면 되고, undo라면 t초 동안의 명령은 다 지워지므로 벡터에 push된 시간 중에수행한 시간 - t보다 작은 시간 중 가장 큰 시간의 문자열을 가져오면 된다. 반복문을 통해 벡터 전체를 탐색하여 수행한 시간- t와 같거나 큰 시간을 찾아 해당 문자열 정보의 인덱스 - 1을 하면 undo 명령을 했을 때 얻어지는 문자열을 얻을 수 있다.

 

아래는 코드.

더보기
#include <iostream>
#include <vector>
#include <utility>
#include <string>
using namespace std;

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

	int N;
	string command, c;
	int sec;
	cin >> N;
	vector<pair<int, string>> v;
	v.push_back(make_pair(0, ""));
	for (int i = 0; i < N; i++)
	{
		cin >> command >> c >> sec;
		if (command == "type")
		{
			string lastString = v.back().second;
			v.push_back(make_pair(sec, lastString + c));
		}
		else
		{	int index = v.size() - 1;
			for (int i = 0; i < v.size(); i++)
			{
				if (sec - stoi(c) <= v.at(i).first)
				{
					index = i - 1;
					break;
				}
			}
			if (index == -1)
			{
				v.push_back(make_pair(sec, ""));
			}
			else
			{
				v.push_back(make_pair(sec, v.at(index).second));
			}
		}
	}
	if (v.back().second != "")
	{
		cout << v.back().second << "\n";
	}
	return 0;
}

 

 

'알고리즘 > 백준' 카테고리의 다른 글

[백준 14247] 나무 자르기 (C++)  (0) 2024.05.13
[백준 10799] 쇠막대기 (C++)  (0) 2024.05.12
[백준 10427] 빚 (C++)  (0) 2024.05.09
[백준 2559] 수열 (C++)  (0) 2024.05.08
[백준 2502] 떡 먹는 호랑이 (C++)  (0) 2024.05.07