*LeetCode-Binary Tree Level Order Traversal
자바
Queue queueA = new LinkedList();
Queue queueB = new PriorityQueue();
queue 를 실현 하기 위해 linkedlist 를 사용 하여 우선 순위 가 없 는 단순 한 fifo 를 실현 합 니 다.
queue 의 설명 을 보 세 요. 안에 두 개의 function 이 있 는데 각각 대응 합 니 다.
offer peek poll 은 모두 반환 값 을 가지 고 있 습 니 다.
그 다음 에 while 에서 각 층 의 node 개 수 를 제어 하 는 것 을 주의해 야 합 니 다. 바로 quue 에 현재 몇 개의 node 가 있 습 니 다. 먼저 num 을 가 져 오 는 것 을 기억 하 세 요.
public class Solution {
public List<List<Integer>> levelOrder(TreeNode root) {
Queue <TreeNode> que = new LinkedList<TreeNode>();
List<List<Integer>> ans = new ArrayList<List<Integer>>();
if ( root == null)
return ans;
que.offer(root);
while (!que.isEmpty()){
int num = que.size();
List <Integer> list = new ArrayList<Integer>();
for ( int i = 0; i < num; i ++ ){
if ( que.peek().left != null )
que.offer(que.peek().left);
if ( que.peek().right != null )
que.offer(que.peek().right);
list.add( que.poll().val);
}
ans.add(list);
}
return ans;
}
}
재 귀적 방법:
public List<List<Integer>> levelOrderBottom(TreeNode root) {
LinkedList<List<Integer>> list = new LinkedList<List<Integer>>();
addLevel(list, 0, root);
return list;
}
private void addLevel(LinkedList<List<Integer>> list, int level, TreeNode node) {
if (node == null) return;
if (list.size()-1 < level) list.addFirst(new LinkedList<Integer>());
list.get(list.size()-1-level).add(node.val);
addLevel(list, level+1, node.left);
addLevel(list, level+1, node.right);
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.