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;
    }
}
原文地址:https://www.cnblogs.com/qingjiuling/p/14175225.html