이 문제 딱 보자마자 순회가 생각났고 순회가 주어질 때 트리를 구하는 것 같다..
하지만 아니었습니다~~ ^~^
이참에 순회 공부했다.
그런데 이건 순회가 아니라 그냥 하나하나씩 다 돌아보는 거라서 스택을 써야할 듯
top 바로 아래에 있는 거랑 같다면 pop하는 식으로 구현했음
tmi지만 제목이 트리라서 트리...?? 덜덜 떨었는데 스택이군..
#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
#include <functional>
#include <string>
#include <queue>
#include <stack>
#include <set>
#include <map>
#include <cmath>
#define xx first
#define yy second
#define all(x) (x).begin(), (x).end()
using namespace std;
using i64 = long long;
using ii = pair<int, int>;
using ii64 = pair<i64, i64>;
int stack_[200005];
int main()
{
int n;
scanf("%d", &n);
int top = 1;
vector<int> v(n);
vector<int> ans(n, -1);
int max_num = 0;
for (int i = 0; i < n; i++)
{
scanf("%d", &v[i]);
if (max_num < v[i])
max_num = v[i];
}
stack_[0] = -1;
stack_[1] = v[0];
ans[v[0]] = -1;
for (int i = 1; i < n; i++)
{
if (v[i] != stack_[top-1])
{
if (ans[v[i]] == -1)
ans[v[i]] = stack_[top];
stack_[++top] = v[i];
}
else
{
top--;
}
}
printf("%d\n", max_num+1);
for (int i = 0; i <= max_num; i++)
printf("%d ", ans[i]);
return 0;
}
'백준' 카테고리의 다른 글
1493 박스 채우기 (0) | 2020.08.30 |
---|---|
10713 기차 여행 (0) | 2020.08.28 |
3187 양치기 꿍 (0) | 2020.08.25 |
2435 기상청 인턴 신현수 (0) | 2020.08.25 |
17212 달나라 토끼를 위한 구매대금 지불 도우미 (0) | 2020.08.25 |