<Algorithm> 73. 1068번 트리
by BFine반응형
1. 1068번 트리
트리의 단말노드를 찾는 문제
트리문제를 접근할때 한쪽에만 자식들이 달려있는 경우를 생각해야 될 것 같다.
이진트리인줄 알고 접근했다가 꽤 시간이 걸린문제 이진트리라고 명시가 안되있는 경우 자식이 꼭 2개까지만 있는 경우는 없다.
노드가 삭제될때 상위노드의 자식이 하나 뿐이였다면 부모가 단말노드가 된다.
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 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 | import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.StringTokenizer; public class Main { static ArrayList<Node>[] alists; static int count = 0; public static void main(String[] args) throws NumberFormatException, IOException { BufferedReader br =new BufferedReader(new InputStreamReader(System.in)); int N = Integer.parseInt(br.readLine()); alists = new ArrayList[N]; StringTokenizer st = new StringTokenizer(br.readLine()); for(int i = 0; i < N; i ++) { alists[i] = new ArrayList<>(); } int root = 0; for(int i = 0; i < N; i ++) { int parent = Integer.parseInt(st.nextToken()); if(parent != -1) alists[parent].add(new Node(i)); else root = i; } int remove = Integer.parseInt(br.readLine()); searchTree(root, remove, 0); System.out.println(count); } private static void searchTree(int vertax, int remove, int pNodeCount) { if(vertax == remove) { if(pNodeCount == 1) { count++; } return; } if(alists[vertax].size()==0) { count ++; return; } for(Node node:alists[vertax]) { searchTree(node.vertax, remove, alists[vertax].size()); } /*if(alists[vertax].size() == 1) { searchTree(alists[vertax].get(0).vertax,remove,1); }else { searchTree(alists[vertax].get(0).vertax,remove,2); searchTree(alists[vertax].get(1).vertax,remove,2); }*/ } } class Node{ int vertax; public Node(int vertax) { super(); this.vertax = vertax; } } | cs |
참고 & 출처
반응형
'공부(2018~2019) - 스킨변경전 > Algorithm' 카테고리의 다른 글
<Algorithm> 75. 1507번 궁금한 민호(floyd) (0) | 2018.09.03 |
---|---|
<Algorithm> 74. 5567번 결혼식 (0) | 2018.09.03 |
<Algorithm> 72. 4963번 섬의 개수(DFS) (0) | 2018.09.01 |
<Algorithm> 70. 2819번 격자판의 숫자 이어붙이기(SW Expert) (0) | 2018.08.29 |
<Algorithm> 69. 2163번 초콜릿 자르기 (0) | 2018.08.29 |
블로그의 정보
57개월 BackEnd
BFine