zoukankan      html  css  js  c++  java
  • 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;
        }
    }
  • 相关阅读:
    map-count
    map-count
    map-constructors
    map-constructors
    multiset-find
    multiset-find
    multiset-insert
    C++ string详解
    treap(树堆)
    程序设计语言的变革
  • 原文地址:https://www.cnblogs.com/qingjiuling/p/14175225.html
Copyright © 2011-2022 走看看