<aside> 💛

시간 제한 : 2초, 난이도 : 실버1, 백준 : 1068번

</aside>

리프 노드 → 자식의 개수가 0인 노드

import java.util.ArrayList;
import java.util.Scanner;
public class Practice68 {
	static ArrayList<Integer>[] tree;
	static boolean[] visited;
	static int answer = 0;
	static int deleteNode = 0;
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		
		int N = sc.nextInt();
		tree = new ArrayList[N];
		
		visited = new boolean[N];
		int root = 0;
		for(int i = 0; i < N; i++) {
			tree[i] = new ArrayList<Integer>();
		}
		
		for(int i = 0; i < N; i++) {
			int p = sc.nextInt();
			if(p != -1) {
				tree[i].add(p);
				tree[p].add(i);
			}else
				root = i;
		}
		deleteNode = sc.nextInt();
		if(deleteNode == root)
			System.out.println(0);
		else {
			DFS(root);
			System.out.println(answer);
		}
		
		sc.close();
	}
	static void DFS(int number) {
		visited[number] = true;
		int cNode = 0;
		for(int i : tree[number]) {
			if(visited[i] == false && i != deleteNode) {
				cNode++;
				DFS(i);
			}
		}
		if(cNode == 0) { //자식노드가 0개일 때
			answer++;
		}
	}	

}