LeetCode_8_树----二叉树的锯齿形层次遍历

大家好🙌!我是你们的好朋友,大数据老虾😀。相遇是缘,既然来了就拎着小板凳坐下来一起唠会儿😎,如果在文中有所收获,请别忘了一键三连,你的鼓励,是我创作的动力😁,废话不多说,直接开干😎

先别急着走,文末干货,记得拎着小板凳离开的时候也给它顺走🤣

二叉树的锯齿形层次遍历

题目

给出二叉树的根节点root,返回其节点值得锯齿形层序遍历。(即先从左往右,在从右往左进行下一步遍历,以此进行类推,层与层之间交替进行)

示例1:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5HXOmGxI-1647241998393)(Images/1647240692019.png)]

input:root = [3, 9, 20, null, null, 15, 7]
output:[[3], [20, 9], [15, 7]]

示例2:

input:root = [1]
output:[[1]]

示例3:

input:root = []
output:[]

方法1:广度优先遍历

解析:

此题属于二叉树得层序遍历的升级,最有要求输出有有所变化,要求按层数的奇偶来决定每一层最后的输出顺序。

规定二叉树的根节点为第0层,如果当前的层数是偶数,从左至右输出当前层的节点值,否则,从右至左输出当前层的节点值。

修改广度优先搜索:

1、对树进行逐层遍历,用队列维护当前层的所有元素。

2、当队列不为空的时候,求得当前队列的长度 size。

3、每次从队列中取出 size 个元素进行拓展,然后进行下一次迭代。

为满足题目要求的返回值为「先从左往右,再从右往左」交替输出的锯齿形, 用「双端队列」的数据结构来维护当前层节点值输出的顺序。

双端队列是一个可以在队列任意一端插入元素的队列。在广度优先搜索遍历当前层节点拓展下一层节点的时候仍然从左往右按顺序拓展,但是对当前层节点的存储维护一个变量 isOrderLeft 记录是从左至右还是从右至左的:

1、如果从左至右,我们每次将被遍历到的元素插入至双端队列的末尾。

2、如果从右至左,我们每次将被遍历到的元素插入至双端队列的头部。

Java实现代码

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;
    }
}

复杂度分析

  • 时间复杂度:O(N),其中 N 为二叉树的节点数。每个节点会且仅会被遍历一次。

  • 空间复杂度:O(N)。需要维护存储节点的队列和存储节点值的双端队列,空间复杂度为 O(N)。

文末彩蛋🤩

找资料很累吧,别急客官,俺统统安排上。程序员不可缺少的书籍,程序员经典名言:"收藏了就等于学会啦"
图灵程序丛书300+
Linux实战100讲
Linux书籍
计算机基础硬核总结
计算机基础相关书籍
操作系统硬核总结
Java自学宝典
Java学习资料
Java硬核资料
Java面试必备
Java面试深度剖析
阿里巴巴Java开发手册
MySQL入门资料
MySQL进阶资料
深入浅出的SQL
Go语言书籍
我的个人仓库:私人仓库

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值