트리의 부모 찾기
https://www.acmicpc.net/problem/11725
| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 1 초 | 256 MB | 60311 | 26553 | 18833 | 42.193% |
문제
루트 없는 트리가 주어진다.
이때, 트리의 루트를 1이라고 정했을 때, 각 노드의 부모를 구하는 프로그램을 작성하시오.
입력
첫째 줄에 노드의 개수 N (2 ≤ N ≤ 100,000)이 주어진다.
둘째 줄부터 N-1개의 줄에 트리 상에서 연결된 두 정점이 주어진다.
출력
첫째 줄부터 N-1개의 줄에 각 노드의 부모 노드 번호를 2번 노드부터 순서대로 출력한다.
예제 입력 1
7 1 6 6 3 3 5 4 1 2 4 4 7
예제 출력 1
4 6 1 3 1 4
예제 입력 2
12 1 2 1 3 2 4 3 5 3 6 4 7 4 8 5 9 5 10 6 11 6 12
예제 출력 2
1 1 2 3 3 4 4 5 5 6 6
출처
알고리즘 분류

통과괸 코드
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
struct Node
{
int _Number;
int _Parent = -1;
vector<int> _Nodes;
Node(int p_Number)
{
_Number = p_Number;
}
};
queue<int> _MyQueue;
vector<Node> _NodesV;
int _N;
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
cin >> _N;
for (int i = 0; i <= _N; i++) {
Node _NewNode(i);
_NodesV.push_back(_NewNode);
}
for (int i = 1; i < _N; i++) {
int _First, _Second;
cin >> _First >> _Second;
_NodesV[_First]._Nodes.push_back(_Second);
_NodesV[_Second]._Nodes.push_back(_First);
}
_MyQueue.push(1);
while (!_MyQueue.empty()) {
int CntNode = _MyQueue.front();
_MyQueue.pop();
for (auto& it : _NodesV[CntNode]._Nodes) {
if (_NodesV[it]._Parent != -1) continue;
_NodesV[it]._Parent = CntNode;
_MyQueue.push(it);
}
}
for (int i = 2; i <= _N; i++) {
cout << _NodesV[i]._Parent << "\n";
}
return 0;
}



![백준 7568번 (덩치, C++) [BAEKJOON]](https://lycos7560.com/wp-content/uploads/boj-og-1.png)