20.12.22 leetcode103
题目链接:https://leetcode-cn.com/problems/binary-tree-zigzag-level-order-traversal/
题意:给你一个二叉树,返回一个类层序遍历数组(奇数层从左到右,偶数层从右到左)。
分析:就是一个bfs,主要讲下JAVA语法方面LinkedList和和ArrayList功能好像没太大区别,就是底层实现不一样。
LinkedList的一些语法可以看这篇文章https://blog.csdn.net/I_peter/article/details/50999720
.offer()和.add()感觉也没什么功能上的区别,leetcode题解总是喜欢玩些花语法。。。
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */ class Solution { public List<List<Integer>> zigzagLevelOrder(TreeNode root) { List<List<Integer> > ans = new LinkedList<List<Integer>>(); if(root==null)return ans; Queue<TreeNode> nodeQueue = new LinkedList<TreeNode>(); nodeQueue.offer(root); boolean isOrderLeft = true; while(!nodeQueue.isEmpty()){ Deque<Integer> levelList = new LinkedList<Integer>(); int size = nodeQueue.size(); for(int i=0;i<size;i++){ TreeNode curNode = nodeQueue.poll(); if(isOrderLeft){ levelList.offerLast(curNode.val); }else{ levelList.offerFirst(curNode.val); } if(curNode.left!=null)nodeQueue.offer(curNode.left); if(curNode.right!=null)nodeQueue.offer(curNode.right); } ans.add(new LinkedList<Integer>(levelList)); isOrderLeft=!isOrderLeft; } return ans; } }