LintCode领扣 题解丨 微软常考题:二叉树的锯齿形层次遍历

简介: LintCode领扣 题解丨 微软常考题:二叉树的锯齿形层次遍历

给出一棵二叉树,返回其节点值的锯齿形层次遍历(先从左往右,下一层再从右往左,层与层之间交替进行)

在线评测地址:https://www.lintcode.com/problem/binary-tree-zigzag-level-order-traversal/?utm_source=sc-tianchi-sz0818

样例 1:

输入:{1,2,3}
输出:[[1],[3,2]]
解释:

1

/ \
2 3
它将被序列化为 {1,2,3}
样例 2:

输入:{3,9,20,#,#,15,7}
输出:[[3],[20,9],[15,7]]
解释:

3

/ \
9 20

/  \

15 7
它将被序列化为 {3,9,20,#,#,15,7}
【题解】

算法:树的层次遍历

层次遍历,可以运用广度遍历的思想实现从上往下的逐层遍历。从头结点开始逐层遍历,开辟一个新队列,让头结点入队并计算此时的长度,每次都将当前层的子节点全部压入队列,然后对下一层的节点进行遍历,再将下一层的子节点压入队列,不断循环,一直遍历到底层,判断的终止条件就是队列不为空。

循环里面,队列头出队,判断其是否有左右子结点,如果有,则将此点的子节点入队,但此时还不需要更新队列的长度,当前队列的长度是每层的长度。当这层的长度减为0时,就说明这层的遍历结束,开始更新长度为下一层的长度。
出队的元素的值按照一层层压入结果数组
因为题目锯齿形遍历
我们用一个isforward标记当前方向,每遍历完一层,如果是反向的,则将这层的节点数组倒序,然后将这层的集合压入结果
复杂度分析

时间复杂度O(n)
n为节点数量
空间复杂度O(n)
存下所有点的信息 n为节点数量
public class Solution
{

/**
 * @param root: A Tree
 * @return: A list of lists of integer include the zigzag level order traversal of its nodes' values.
 */
public List<List<Integer>> zigzagLevelOrder(TreeNode root){
    List<List<Integer>> ans = new ArrayList<List<Integer>>();
    if (root == null) {
        return ans;
    }
    Queue<TreeNode> q = new LinkedList<TreeNode>();
    //正反向标志
    boolean isForward = true;
    q.offer(root);
    while (!q.isEmpty()) {
        int size = q.size();
        List<Integer> subList = new ArrayList<Integer>();
        for (int i = 0 ; i < size ; i++) {
            TreeNode treeNode = q.poll();
            subList.add(treeNode.val);
            if (treeNode.left != null) { 
                q.offer(treeNode.left);
            }
            if (treeNode.right != null) {
                q.offer(treeNode.right);
            }
        }
        //根据标志来确认当前层遍历的方向
        if (!isForward) {
            Collections.reverse(subList);//翻转
        }
        ans.add(subList);
        //方向反转
        isForward = !isForward;
    }
    return ans;
}

}
更多题解参见:给出一棵二叉树,返回其节点值的锯齿形层次遍历(先从左往右,下一层再从右往左,层与层之间交替进行)

在线评测地址:

LintCode 领扣

www.lintcode.com
样例 1:

输入:{1,2,3}
输出:[[1],[3,2]]
解释:

1

/ \
2 3
它将被序列化为 {1,2,3}
样例 2:

输入:{3,9,20,#,#,15,7}
输出:[[3],[20,9],[15,7]]
解释:

3

/ \
9 20

/  \

15 7
它将被序列化为 {3,9,20,#,#,15,7}
【题解】

算法:树的层次遍历

层次遍历,可以运用广度遍历的思想实现从上往下的逐层遍历。从头结点开始逐层遍历,开辟一个新队列,让头结点入队并计算此时的长度,每次都将当前层的子节点全部压入队列,然后对下一层的节点进行遍历,再将下一层的子节点压入队列,不断循环,一直遍历到底层,判断的终止条件就是队列不为空。

循环里面,队列头出队,判断其是否有左右子结点,如果有,则将此点的子节点入队,但此时还不需要更新队列的长度,当前队列的长度是每层的长度。当这层的长度减为0时,就说明这层的遍历结束,开始更新长度为下一层的长度。
出队的元素的值按照一层层压入结果数组
因为题目锯齿形遍历
我们用一个isforward标记当前方向,每遍历完一层,如果是反向的,则将这层的节点数组倒序,然后将这层的集合压入结果
复杂度分析

时间复杂度O(n)
n为节点数量
空间复杂度O(n)
存下所有点的信息 n为节点数量
public class Solution
{

/**
 * @param root: A Tree
 * @return: A list of lists of integer include the zigzag level order traversal of its nodes' values.
 */
public List<List<Integer>> zigzagLevelOrder(TreeNode root){
    List<List<Integer>> ans = new ArrayList<List<Integer>>();
    if (root == null) {
        return ans;
    }
    Queue<TreeNode> q = new LinkedList<TreeNode>();
    //正反向标志
    boolean isForward = true;
    q.offer(root);
    while (!q.isEmpty()) {
        int size = q.size();
        List<Integer> subList = new ArrayList<Integer>();
        for (int i = 0 ; i < size ; i++) {
            TreeNode treeNode = q.poll();
            subList.add(treeNode.val);
            if (treeNode.left != null) { 
                q.offer(treeNode.left);
            }
            if (treeNode.right != null) {
                q.offer(treeNode.right);
            }
        }
        //根据标志来确认当前层遍历的方向
        if (!isForward) {
            Collections.reverse(subList);//翻转
        }
        ans.add(subList);
        //方向反转
        isForward = !isForward;
    }
    return ans;
}

}
更多题解参见九章算法官网:
https://www.jiuzhang.com/solution/binary-tree-zigzag-level-order-traversal/?utm_source=sc-tianchi-sz0818

相关文章
|
数据可视化 数据处理 计算机视觉
Grounded-SAM模型:自动化检测、分割、生成一切
借着Meta发布的Segment Anything视觉大模型,作者团队做了一个最强Zero-Shot视觉应用:最强的Zero-Shot检测器,最强的Zero-Shot分割器,最强的Zero-Shot生成器,三合一模型简称为Grounded-SAM。
|
存储 JavaScript 前端开发
《JavaScript高级程序设计》__ 作用域&内存
前言 大家好,我是HoMeTown,web领域有一本神书大家应该都有看过,这本书我看过两遍,但是每次看都是粗粗的略过一些重要的知识点,甚至一些面试过程中的问题,在这本书里都能找到答案。
38121 3
《JavaScript高级程序设计》__ 作用域&内存
|
存储
树型结构——二叉数
树型结构——二叉数
321 0
树型结构——二叉数
|
前端开发 测试技术 数据库
【Servlet】规范项目结构|基于Mysql+JDBC+Servlet 制作简易网页|实现登录、添加、删除、显示的功能(下)
【Servlet】规范项目结构|基于Mysql+JDBC+Servlet 制作简易网页|实现登录、添加、删除、显示的功能
199 0
|
域名解析 弹性计算 运维
阿里云轻量应用服务器产品功能及最新套餐收费标准参考
阿里云轻量应用服务器是可快速搭建且易于管理的轻量级云服务器;适用于网站搭建,知识效率管理,云端学习环境,电商建设,论坛社区等场景应用。轻量应用服务器的开发环境配置提供基于单台服务器的应用部署,安全管理,运维监控等服务,一站式提升您的服务器使用体验和效率。
|
存储 Shell Linux
|
前端开发 Java 程序员
深入理解Servlet
简介   Servlet(Server Applet),全称Java Servlet,未有中文译文。是用Java编写的服务器端程序。其主要功能在于交互式地浏览和修改数据,生成动态Web内容。
1149 0
|
XML 移动开发 Java
bboss persistent 1.0.4 发布,功能变更清单见正文
bboss persistent 1.0.4 发布,下载地址: https://sourceforge.net/project/showfiles.php?group_id=238653&package_id=302766&release_id=688812    功能变更清单如下:   o 调整com.
818 0
|
5天前
|
人工智能 JSON 监控
Claude Code 源码泄露:一份价值亿元的 AI 工程公开课
我以为顶级 AI 产品的护城河是模型。读完这 51.2 万行泄露的源码,我发现自己错了。
3970 10
|
15天前
|
人工智能 JSON 机器人
让龙虾成为你的“公众号分身” | 阿里云服务器玩Openclaw
本文带你零成本玩转OpenClaw:学生认证白嫖6个月阿里云服务器,手把手配置飞书机器人、接入免费/高性价比AI模型(NVIDIA/通义),并打造微信公众号“全自动分身”——实时抓热榜、AI选题拆解、一键发布草稿,5分钟完成热点→文章全流程!
11600 134
让龙虾成为你的“公众号分身” | 阿里云服务器玩Openclaw

热门文章

最新文章