zoukankan      html  css  js  c++  java
  • leetcode Binary Tree Level Order Traversal I II



    Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, level by level).

    For example:
    Given binary tree {3,9,20,#,#,15,7},

        3
       / 
      9  20
        /  
       15   7

    return its level order traversal as:

    [
      [3],
      [9,20],
      [15,7]
    ]
    /**
     * Definition for binary tree
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ArrayList<ArrayList<Integer>> levelOrder(TreeNode root) {
            ArrayList<ArrayList<Integer>> result=new  ArrayList<ArrayList<Integer>>();
            if(root==null){
                return result;
            }
            LinkedList<TreeNode> queue = new LinkedList<TreeNode>();
            queue.add(root);
            while(!queue.isEmpty()){
                ArrayList<Integer> level=new ArrayList<Integer>();
                int size=queue.size();
                for(int i=0;i<size;i++){
                    TreeNode head=queue.poll();
                    level.add(head.val);
                    if(head.left!=null){
                        queue.add(head.left);
                    }
                    if(head.right!=null){
                        queue.add(head.right);
                    }
                }
                result.add(level);
            }
            return result;
    
        }
    }

    Binary Tree Level Order Traversal  II

    Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root).

    For example:
    Given binary tree {3,9,20,#,#,15,7},

        3
       / 
      9  20
        /  
       15   7
    

    return its bottom-up level order traversal as:

    [
      [15,7],
      [9,20],
      [3]
    ]
    /**
     * Definition for binary tree
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ArrayList<ArrayList<Integer>> levelOrderBottom(TreeNode root) {
             ArrayList<ArrayList<Integer>> result=new  ArrayList<ArrayList<Integer>>();
            if(root==null){
                return result;
            }
            LinkedList<TreeNode> queue = new LinkedList<TreeNode>();
            queue.add(root);
            while(!queue.isEmpty()){
                ArrayList<Integer> level=new ArrayList<Integer>();
                int size=queue.size();
                for(int i=0;i<size;i++){
                    TreeNode head=queue.poll();
                    level.add(head.val);
                    if(head.left!=null){
                        queue.add(head.left);
                    }
                    if(head.right!=null){
                        queue.add(head.right);
                    }
                }
                result.add(0,level);
            }
            return result;
        }
    }
  • 相关阅读:
    Asp.net 后台添加CSS、JS、Meta标签(帮助类)
    Jquery 事件冒泡
    一个例子理解C#位移
    CodeSmith 创建Ado.Net自定义模版(四)
    .NET4.0下网站应用程序用UrlRewriter.dll重写无后缀路径 (在IIS7.5中的配置方法)
    用泛型的IEqualityComparer<T>接口去重复项
    Why MapReduce?
    SYN flood攻击介绍
    tmux使用方法详解
    理解Linux系统负荷
  • 原文地址:https://www.cnblogs.com/lilyfindjobs/p/4068330.html
Copyright © 2011-2022 走看看