二叉树(二)深度遍历和广度遍历

news2025/1/16 21:01:30

一、层序遍历

广度优先搜索:使用队列,先进先出

模板:

1、定义返回的result和用于辅助的队列

2、队列初始化:

root非空时进队

3、遍历整个队列:大循环while(!que.empty())

记录每层的size以及装每层结果的变量(记得每层循环结束后保存结果的值)

4、遍历每层:小循环for或while(size--)

出1进2:先记录当前即将出队的node

node出队,如果孩子节点非空即进队

  vector<vector<int>> levelOrder(TreeNode* root) {
       vector<vector<int>> result;
       //借助队列来实现
       queue<TreeNode*>que;//(先进先出,层序遍历)(保存节点指针,孩子信息才不丢失)
        
        if(root) //先弹进root
          que.push(root);

       while(!que.empty()){//队列不为空时,都要遍历;没有继续加入的,则说明快要遍历完了
          int size=que.size(); //保存当前层的大小
          vector<int> vec;//vec记录每层的节点元素,在循环内定义,不用每次清空

          //将总遍历切割成一层一层的
          while(size--){
            //对一层元素进行操作:出一个根节点(要先记录val),则进两个它的孩子节点(如果有)
             TreeNode*node=que.front();
             vec.push_back(node->val);

             que.pop();

             if(node->left)
               que.push(node->left);
             if(node->right)
               que.push(node->right);
          }

         result.push_back(vec);
       }
       
          return result;
    }

 变式:求层平均值

  vector<double> averageOfLevels(TreeNode* root) {
       vector<double> result;
       queue<TreeNode*> que;

       if(root!=NULL) 
         que.push(root);

        while(!que.empty()){
            int size=que.size();//当前层元素个数
            double sum=0;

            for(int i=0;i<size;i++){
                TreeNode* node=que.front(); //先保存
                sum+=node->val;

                que.pop();//再弹出

                if(node->left)//最后进两个
                  que.push(node->left);
                if(node->right)
                  que.push(node->right);
            }
            result.push_back(sum/size);
        }

       return result;
    }

 注意:最后要用到sum/size;所以不能用while(size--),因为size会改变,而要用for循环

同理,每层循环要记录size,就是因为que.size()也会改变

二、深度遍历(前中后序,递归)

深度优先搜索:使用栈,先进后出

模板:

前序:

   void traversal(TreeNode* cur, vector<int>& vec) {
        if (cur == NULL) return;
        vec.push_back(cur->val);    // 根
        traversal(cur->left, vec);  // 左
        traversal(cur->right, vec); // 右
    }

中序:

void traversal(TreeNode* cur, vector<int>& vec) {
    if (cur == NULL) return;
    traversal(cur->left, vec);  // 左
    vec.push_back(cur->val);    // 根
    traversal(cur->right, vec); // 右
}

后序:

void traversal(TreeNode* cur, vector<int>& vec) {
    if (cur == NULL) return;
    traversal(cur->left, vec);  // 左
    traversal(cur->right, vec); // 右
    vec.push_back(cur->val);    // 根
}

三、对比

1、获取最大深度

 深度优先(前序):

   int getdepth(TreeNode* node) {
        if (node == NULL) return 0;
        int leftdepth = getdepth(node->left);       // 左
        int rightdepth = getdepth(node->right);     // 右
        int depth = 1 + max(leftdepth, rightdepth); // 中
        return depth;
    }

广度优先:

int maxDepth(TreeNode* root) {
        //1、定义结果变量和辅助队列
     int depth=0;
     queue<TreeNode*> que;
        
        //2、队列初始化
     if(root)
      que.push(root);
        
        //3、大循环并记录每层的size
     while(!que.empty()){
        int size=que.size();
         
         //4、小循环:遍历一层,存1出1进2
        while(size--){
          TreeNode*node=que.front();
          
          que.pop();

          if(node->left)
           que.push(node->left);
          if(node->right)
           que.push(node->right);
        }
        depth++;
     }
     return depth;
    }

2、获取最小深度 

深度优先(前序):

    int minDepth(TreeNode* root) {
      if(root==NULL)
       return 0;
      
      int lh=minDepth(root->left);
      int rh=minDepth(root->right);
      if(!root->left&&root->right)
       return 1+rh;
      if(root->left&&!root->right)
       return 1+lh;
      return 1+min(lh,rh);
    }

考虑仅有一个孩子节点时,返回的应是1+子树的最小深度 

广度优先:

 int minDepth(TreeNode* root) {
        //1、定义结果变量和辅助队列
     int depth=0;
     queue<TreeNode*> que;
        
        //2、队列初始化
     if(root)
      que.push(root);
        
        //3、大循环并记录每层的size
     while(!que.empty()){
        int size=que.size();
         
         //4、小循环:遍历一层,存1出1进2
        while(size--){
          TreeNode*node=que.front();
          
          que.pop();

          if(node->left)
           que.push(node->left);
          if(node->right)
           que.push(node->right);

           //如果遇到叶子节点了,说明可以完成最小深度计算了
           if(!node->left&&!node->right)
             return depth+1;//注意是+1(逻辑上要遍历完一层才+1,这里提前结束就提前加)
        }
        depth++;
     }
     return depth;
    }

考虑遇到叶子节点时,就可以返回最小深度了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2154454.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux基础命令以及常识

镜像站点服务器&#xff08;相当于下载的网址&#xff09;也可叫软件源 vim /etc/apt/sources.list 索引文件(网络服务器在本地的缓存) 服务器软件源在本地列出来一个清单&#xff0c;以便于主机进行查询操作 cd /var/lib/apt/lists/ 下载软件包默认存放路径 cd /var/cache/a…

Linux_openEuler_24.03部署Oracle 19c部署安装实测验证(无图形桌面-RPM模式)

前言&#xff1a; 近期对openeuler有点兴趣&#xff0c;顺带在做个开发数据仓项目&#xff0c;那就正好安装个环境做个调测&#xff0c;做个记录放上来做个备录给到大家参考。 openEuler 24.03 LTS&#xff1a;四大升级&#xff0c; 首个AI原生开源操作系统正式发布 openEuler …

【医疗大数据】基于 B2B 的医疗保健系统中大数据信息管理的安全和隐私问题分析

基于 B2B 的医疗保健系统中大数据信息管理的安全和隐私问题分析 1、引言 1-1 医疗大数据的特点 10 V模型&#xff1a;在医疗领域&#xff0c;大数据的特点被描述为10 V&#xff0c;包括价值&#xff08;Value&#xff09;、体量&#xff08;Volume&#xff09;、速度&#xf…

C语言-文件操作-一些我想到的、见到的奇怪的问题

博客主页&#xff1a;【夜泉_ly】 本文专栏&#xff1a;【C语言】 欢迎点赞&#x1f44d;收藏⭐关注❤️ C语言-文件操作-一些我想到的、见到的奇怪的问题 前言1.在不关闭文件的情况下&#xff0c;连续多次调用 fopen() 打开同一个文件&#xff0c;会发生什么&#xff1f;1.1过…

【linux-Day4】linux的基本指令<下>

【linux-Day4】linux的基本指令<下> linux下的基本指令&#x1f4e2;date&#xff1a;显示时间&#x1f4e2;cal&#xff1a;显示公历日历&#x1f4e2;whereis &#xff1a; 查找指令->可执行文件/源代码/帮助手册所在的位置&#x1f4e2;find &#xff1a;在目录中搜…

C++ | Leetcode C++题解之第424题替换后的最长重复字符

题目&#xff1a; 题解&#xff1a; class Solution { public:int characterReplacement(string s, int k) {vector<int> num(26);int n s.length();int maxn 0;int left 0, right 0;while (right < n) {num[s[right] - A];maxn max(maxn, num[s[right] - A]);i…

色彩管理中的Gamma值的理解

目录 广义的Gamma值为什么要将输出和输入做Gamma运算&#xff1f;显示器的Gamma值什么是Gamma值为1.0线性响应?显示器的Gamma值标准是多少?为什么sRGB在Gamma0.45空间&#xff1f;打印机、印刷机Gamma值?印刷机Gamma与显示器的Gamma的比较参考文章 广义的Gamma值 Gamma值的…

YOLOv8改进,YOLOv8替换主干网络为VanillaNet( CVPR 2023 华为提出的全新轻量化架构),大幅度涨点

改进前训练结果: 改进后训练结果: 摘要 基础模型的核心理念是“更多即不同”,这一理念在计算机视觉和自然语言处理领域取得了惊人的成功。然而,变压器模型的优化挑战和固有复杂性呼唤一种向简化转变的范式。在本研究中,引入了VanillaNet,一种拥抱设计优雅的神经网络架构…

Ansible部署与应用基础

由于互联网的快速发展导致产品更新换代速度逐步增长&#xff0c;运维人员每天都要进行大量的维护操作&#xff0c;按照传统方式进行维护使得工作效率低下。这时部署自动化运维就 可以尽可能安全、高效的完成这些工作。 一、Ansible概述 1.什么是Ansible Ansible 是基于 Pytho…

Linux中使用cp命令的 -f 选项,但还是提醒覆盖的问题

问题&#xff1a; linux 在执行cp的命令的时候&#xff0c;就算是执行 cp -f 也还是会提醒是否要进行替换。 问题原因&#xff1a; 查看别名&#xff0c;alias命令&#xff0c;看到cp的别名为cp -i&#xff0c;那就是说cp本身就是自带覆盖提醒&#xff0c;就算我们加上-f 的…

《机器人SLAM导航核心技术与实战》第1季:第9章_视觉SLAM系统

视频讲解 【第1季】9.第9章_视觉SLAM系统-视频讲解 【第1季】9.1.第9章_视觉SLAM系统_ORB-SLAM2算法&#xff08;上&#xff09;-视频讲解 【第1季】9.1.第9章_视觉SLAM系统_ORB-SLAM2算法&#xff08;下&#xff09;-视频讲解 【第1季】9.2.第9章_视觉SLAM系统_LSD-SLAM算法…

TikTok提示“Network is out of reach”怎么处理?

当TikTok提示“Network is out of reach”时&#xff0c;意味着应用无法连接到互联网。导致这一问题的常见原因包括网络连接不稳定、地理限制或网络设置与应用不兼容等。解决方法有&#xff1a;拔除手机卡、关闭手机定位服务、切换至稳定的海外IP网络等。使用TikTok专用网络也可…

用户态缓存:链式缓冲区(Chain Buffer)

目录 链式缓冲区&#xff08;Chain Buffer&#xff09;简介 为什么选择链式缓冲区&#xff1f; 代码解析 1. 头文件与类型定义 2. 结构体定义 3. 宏定义与常量 4. 环形缓冲区的基本操作 5. 其他辅助函数 6. 数据读写操作的详细实现 7. 总结 8. 结合之前的内容 9. 具…

利用LRZ压缩与Base64编码实现高效文件上传

引言 在当今互联网时代&#xff0c;文件上传已成为众多在线服务不可或缺的一部分&#xff0c;尤其是在社交媒体平台上的照片分享和云存储服务中的文档管理等场景&#xff0c;高效且安全的文件上传机制对于保障用户体验至关重要。 为此&#xff0c;本文将介绍一种结合了LRZ压缩…

汇川AM400脉冲轴控制(轴控功能块ST源代码)

汇川AM400如何和编程软件通信连接 汇川AM400PLC如何和编程软件通信连接_汇川am400读取程序-CSDN博客文章浏览阅读159次。本文介绍了如何使用CODESYS编程软件与汇川AM400PLC进行通信连接,包括扫描网络、修改IP地址、刷新日志和下载监控程序的步骤。同时,文章提到了CODESYS编程…

灯塔:JavaScript

Web标准也称为网页标准&#xff0c;由一系列的标准组成&#xff0c;大部分由W3C&#xff08;World Wide Web Consortium,万维网联盟&#xff09;负责制定。 三个组成部分&#xff1a; HTML&#xff1a;负责网页的基本结构&#xff08;页面元素和内容&#xff09;。 CSS&…

go 安装依赖超时

一、配置代理 go env -w GO111MODULEon go env -w GOPROXYhttps://goproxy.io,direct go get github.com/unidoc/unioffice

ODrive电机驱动算法VScode环境配置笔记教程

1、ODrive基本介绍 ODrive 是一个开源的优秀电机控制器项目&#xff0c;旨在为各种应用提供高性能、高可靠性的电机控制解决方案。这个项目是专门用于驱动无刷直流电机&#xff08;BLDC&#xff09;和永磁同步电机&#xff08;PMSM&#xff09;的高性能开源伺服控制系统。ODriv…

AI绘制调整虚线教程

1、打开ai的软件&#xff0c;执行菜单栏中的文件—新建&#xff0c;新建一个大小任意的画板&#xff0c;画板大小根据自己的需要来设置。 2、选择工具箱中的直线段工具&#xff0c;将填充设置为无&#xff0c;描边设置为黑色&#xff0c;描边大小稍微设置大一点&#xff0c;画一…

【学习笔记】STM32F407探索者HAL库开发(五)F407时钟系统配置

【学习笔记】STM32F407探索者HAL库开发&#xff08;四&#xff09;F407时钟系统配置 1 F407_CubeMX时钟树配置&#xff08;传送门&#xff09;2 STM32F407时钟树2.1 STM32F407时钟系统图2.2 STM32F103时钟树简图2.2.1 高速部分2.2.2 低速部分 2.3 时钟源2.3.1 外部时钟源2.3.2 …