当前位置: 首页 > news >正文

二叉树层序遍历的三种情况(总结)

这道题就是一个比较简单的层序遍历,只需要利用队列存放二叉树结点,队列的size代表每层的节点数也就是平均值的除数,利用一个结果数组记录每层平均值,最后返回。

需要注意的是,平均值定义成double类型。

代码如下:

class Solution {
    public List<Double> averageOfLevels(TreeNode root) {
        // 结果数组
        List<Double> results = new ArrayList<>();
        if (root == null) {
            return results;
        }

        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        while (!queue.isEmpty()) {
            // 当前层节点数量
            int LevelSize = queue.size();
            // 当前节点值的总和
            double levelSum = 0;
            // 遍历当前层所有节点
            for (int i = 0; i < LevelSize; i++) {
                // 从队列中取出一个节点
                TreeNode node = queue.poll();
                levelSum += node.val;
                if (node.left != null) {
                    queue.offer(node.left);
                }
                if (node.right != null) {
                    queue.offer(node.right);
                }

            }
            double average = levelSum / LevelSize;
            results.add(average);

        }
        return results;

    }
}

这道题其实就是简单的二叉树层序遍历,只不过把每层的节点遍历单独拿了出来,那么其实很简单。创建一个嵌套列表List<List<Integer>> res = new ArrayList<List<Integer>>(),每层的结果用一维列表存储,最后把每层结果存进嵌套列表输出即可。

代码如下:

class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> res=new ArrayList<List<Integer>>();
        if(root==null){
            return res;
        }
        Queue<TreeNode>queue=new LinkedList<TreeNode>();
        queue.offer(root);
        while(!queue.isEmpty()){
            List<Integer>level=new ArrayList<Integer>();
            int currentSize=queue.size();
            for(int i=1;i<=currentSize;++i){
                TreeNode node=queue.poll();
                level.add(node.val);
                if(node.left!=null){
                    queue.offer(node.left);
                }
                if(node.right!=null){
                    queue.offer(node.right);
                }
             
            }
               res.add(level);
        
        }
            return res;
        }

    }

这道题就用到了一种平常不怎么常用的数据结构,双端队列,利用一个bool 变量来表示该层是从左往后还是从右往左

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

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

代码如下:
 

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

相关文章:

  • ResponseUtil.out 方法分析
  • Golang连接使用SqlCipher
  • android studio 界面启动模拟器无反应——从命令行启动模拟器
  • 一分钟学会JavaScript 变量
  • vxe-table实现动态列
  • 2025年度福建省职业院校技能大赛高职组“信息安全管理与评估”赛项规程
  • [c++]--类和对象
  • 【uniapp*vue3】app/h5 webview通讯方案
  • UE5中按钮圆角,设置边框
  • Redis使用手册
  • 使用Hardhat实现ERC20 代币合约详解
  • 通俗易懂的DOM事件模型指南
  • 数据结构:哈希表(unordered_map)
  • 1.13作业
  • 人工智能之自动驾驶技术体系
  • 大学本科教务系统设计方案,涵盖需求分析、架构设计、核心模块和技术实现要点
  • 长尾关键词优化三步法:提升SEO搜索排名实战
  • MATLAB | 设置滑动窗口计算栅格数据的CV变异系数
  • MySQL数据库表约束详解
  • 一些时间方法
  • 湃书单|澎湃新闻编辑们在读的14本书:后工作时代
  • 长三角首次,在铁三赛事中感受竞技与生态的共鸣
  • 上海锦江乐园摩天轮正在拆除中,预计5月底6月初拆完
  • 著名植物学家、园艺学家,国际植物园协会原主席贺善安逝世
  • 陕西一村民被冒名贷款40余万续:名下已无贷款,将继续追责
  • 加拿大新政府宣誓就职