跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 巨硬家面试题:二叉树的锯齿形层次遍历
未分類
3 9 月 2020

巨硬家面试题:二叉树的锯齿形层次遍历

巨硬家面试题:二叉树的锯齿形层次遍历

資深大佬 : zzzrf 18

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

在线做题地址→

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

更多题解参见

大佬有話說 (2)

  • 資深大佬 : vicsun2020

    这么容易的嘛

  • 主 資深大佬 : zzzrf

    @vicsun2020 hard 题也会有,也有相对容易的题

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具