首页 > 其他 > 详细

LeetCode:103 二叉树的锯齿形层次遍历

时间:2020-10-03 11:16:18      阅读:53      评论:0      收藏:0      [点我收藏+]

我写的bug也太多了

class Solution {
    public List<List<Integer>> zigzagLevelOrder(TreeNode root) {
        List<List<Integer>> res = new LinkedList<List<Integer>>();
        if(root==null){
            return res;
        }
        int t=1;
        List<TreeNode> que = new ArrayList<TreeNode>();
        que.add(root);
        while(que.size()!=0){
            t = t % 2;
            int size = que.size();
            List<Integer> tmp = new LinkedList<Integer>();
            if(t==1){
            for(int i=1;i<=size;i++){
                TreeNode n = que.remove(0);
                if(n.left!=null)
                    que.add(n.left);
                if(n.right!=null)
                    que.add(n.right);
                tmp.add(n.val);
            }
            t++;
            }
            else{
                t++;
                for(int i=1;i<=size;i++){
                    TreeNode n = que.remove(0);
                    if(n.left!=null)
                        que.add(n.left);
                    if(n.right!=null)
                        que.add(n.right);
                    tmp.add(0,(Integer)n.val);
                } 
            }
            res.add(tmp);
        }
        return res;
    }
}

 

LeetCode:103 二叉树的锯齿形层次遍历

原文:https://www.cnblogs.com/dloooooo/p/13763557.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!