Post

Baekjoon1068-트리

Baekjoon1068-트리

백준 사이트 1068 - 트리 문제입니다.

1. 문제

https://www.acmicpc.net/problem/1068


2. Input , Output


3. 분류 및 난이도

DFS 문제입니다.
백준에서는 Slive1 난이도를 책정하고 있습니다.


4. 생각한 것들

  • 트리 구현을 어떻게 할까..?
    • 배열을 사용하면 일자로 트리가 진행될 경우 2^50의 배열의 크기가 필요하므로 배열로 만들 수 없습니다.
    • 그리고 이진트리라는 말이 없으므로 자식이 여러개일 수 있습니다. 벡터를 통해 만들어줍니다.
  • DFS 조건문?
    • 트리 자식을 돌아다니다가 remove 값으로 들어온 트리자식을 만나면 return을 해버려 방문을 중단합니다.
    • 만약 자식이 1명이고 마침 그 자식이 제거해야하는 것이면 부모 노드는 리프노드가 되므로 갯수를 세주고 방문을 돌아갑니다.
  • 예외가 좀 많아서 정답률이 낮은 것 같습니다.

5. code

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
#include<iostream>
#include<vector>
using namespace std;
vector<int> v[51];
int removenode = 0;
int result = 0;
void DFS(int now)
{
	if (removenode == now)
		return;
	if (v[now].size() == 0)
	{
		++result;
		return;
	}
	else if (v[now].size() == 1)
	{
		if (v[now][0] == removenode)
		{
			++result;
		}
	}
	for (int i = 0; i < v[now].size(); ++i)
		DFS(v[now][i]);
	
}

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

	int n;

	int node = 0;
	int temp = 0;
	int remove = 0;

	cin >> n;
	for (int i = 0; i < n; ++i)
	{
		cin >> temp;
		if (temp != -1)
		{
			v[temp].push_back(i);
		}
		else
			node = i;
	}
	cin >> removenode;
	DFS(node);
	cout << result;
	
	
}



6. 후기

DFS같은 재귀는 언제나 어려운것 같습니다.
BFS만세

This post is licensed under CC BY 4.0 by the author.