Middle-题目70:103. Binary Tree Zigzag Level Order Traversal

原创 2016年05月31日 16:40:56

题目原文:
Given a binary tree, return the zigzag level order traversal of its nodes’ values. (ie, from left to right, then right to left for the next level and alternate between).

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

    3
   / \
  9  20
    /  \
   15   7

return its zigzag level order traversal as:
[
[3],
[20,9],
[15,7]
]
题目大意:
给出一个二叉树,求锯齿形遍历结果。
题目分析:
其实还是基于层次遍历的,在Easy-题目27基础上加入一个flag,记录该行是应该正向还是应该反向就好了。
源码:(language:java)

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<List<Integer>> zigzagLevelOrder(TreeNode root) {
        Queue<TreeNode> queue=new LinkedList<TreeNode>();
        Queue<Integer> levelqueue=new LinkedList<Integer>();

        queue.add(root);
        levelqueue.add(1);
        boolean isReverse = true;
        List<List<Integer>> result=new ArrayList();
        List<Integer> temp=new ArrayList<Integer>();
//      temp.add(root.val);
//      result.add(temp);
        if(root==null)
            return result;
        while(!queue.isEmpty())
        {
            TreeNode current=queue.remove();
            int curLevel=levelqueue.remove();
            //System.out.println(current.val+" level="+curLevel);

            if(curLevel==result.size())
            {
                temp.add(current.val);
            }
            else
            {
                if(isReverse)
                    Collections.reverse(temp);
                result.add(temp);               
                isReverse = !isReverse;
                temp=new ArrayList<Integer>();
                temp.add(current.val);  
            }
            if(current.left!=null)
            {
                queue.add(current.left);
                levelqueue.add(curLevel+1);
            }
            if(current.right!=null)
            {
                queue.add(current.right);
                levelqueue.add(curLevel+1);
            }
        }
        if(isReverse)
            Collections.reverse(temp);
        result.add(temp);
        result.remove(0);
    //  Collections.reverse(result);
        return result;        
    }
}

成绩:
4ms,beats 4.14%,众数3ms,45.49%

版权声明:完整版Leetcode题解请出门左转https://github.com/cmershen1/leetcode/tree/master/docs

Binary Tree Traversal二叉树遍历方法总结

Binary Tree Traversal二叉树遍历方法总结这里总结的二叉树遍历分为两大类: 深度优先(depth-first traversal) 广度优先(breadth-first traver...
  • jackey_jk
  • jackey_jk
  • 2016年04月01日 02:58
  • 760

pat 甲1127. ZigZagging on a Tree (已知后序及中序建树,并层次往返输出)

1127. ZigZagging on a Tree (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 1...
  • qq_27601815
  • qq_27601815
  • 2017年03月05日 18:01
  • 826

把二叉树打印成多行 按之字形顺序打印二叉树 binary tree zigzag level order traversal

把二叉树打印成多行 题目描述 从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。 import java.util.*; /* public class TreeNod...
  • DuanLiuchang
  • DuanLiuchang
  • 2016年09月12日 21:02
  • 365

LeetCode 144 Binary Tree Preorder Traversal(二叉树的前序遍历)+(二叉树、迭代)

翻译给定一个二叉树,返回其前序遍历的节点的值。例如: 给定二叉树为 {1,#, 2, 3} 1 \ 2 / 3 返回 [1, 2, 3]备注:用递归是微不足道的,...
  • NoMasp
  • NoMasp
  • 2016年03月19日 16:15
  • 3078

Binary Tree Level Order Traversal II 从底部倒着输出二叉树每一层的元素

Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left...
  • chenyx90
  • chenyx90
  • 2016年01月07日 13:54
  • 146

Binary Tree Level Order Traversal II 二叉树层次遍历(广搜,queue)(重重)

题目: 点击打开链接 解答: 上一题采用的深搜+记录深度的fangh
  • skyoceanlover
  • skyoceanlover
  • 2014年08月24日 21:55
  • 530

二叉树 level order 遍历问题汇总

一 如何确定层结束? 1 维护一个levelEnd,如果当前结点是level end,更新levelEnd 为queue.back(),注意先判断queue是否empty,(最后一层结束后,queue...
  • binling
  • binling
  • 2014年12月26日 16:29
  • 396

二叉搜索树(Binary Search Tree )的定义及分析

定义:     二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 每个结点都有一个作为搜索依据的关键码(key),所有结点的关键码互不相同。 左子树(如果非空)上所...
  • jsh13417
  • jsh13417
  • 2013年01月22日 21:59
  • 3331

二叉搜索树(Binary Search Tree)的插入与删除

二叉搜索树的插入关键是要找到元素应该插入的位置,可以采用与Find类似的方法。 二叉搜索树的删除则要考虑三种情况:   1.要删除的是叶节点:直接删除,并再修改其父节点指针置为NULL ...
  • song_hui_xiang
  • song_hui_xiang
  • 2015年08月16日 13:10
  • 978

数据结构(Java语言)——BinarySearchTree简单实现

二叉树的一个重要应用是它们在查找中的使用。使二叉树成为二叉查找树的性质是,对于树中的每个节点X,它的左子树中所有项的值都大于X中的项。注意,这意味着该树所有的元素都可以用某种一致的方式排序。 现在给出...
  • zhang_zp2014
  • zhang_zp2014
  • 2015年08月14日 21:55
  • 926
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Middle-题目70:103. Binary Tree Zigzag Level Order Traversal
举报原因:
原因补充:

(最多只允许输入30个字)