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

Day23-二叉树的层序遍历(广度优先搜素)

今天只看了层序遍历

思路如下:一层层的去吧结果遍历到结果数组中。

层序遍历结果为:[1, 2, 3, 4, 5, 6]。

前面迭代方法是用栈去模拟的,那么层序遍历可以用队列去模拟:

先把根节点加入队列,然后在队列弹出来元素之前用一个node去指向它,弹出来元素之后先把node->val加入一维数组,然后用node去把它的左右孩子加入队列。

每遍历完一层的节点之后把一维数组加入结果数组。

个人感觉需要注意的是一维数组和node节点的创建一定是要在while循环里面。因为需要每次重新计算当前队列的大小!!!

这个可以当作一个模板:

层序遍历的思路基本上就是这样了。

class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> res;    //存放结果数组queue<TreeNode *> que;  //存储每一层的节点if(root == nullptr) return res; //根节点不为空的话就开始遍历que.push(root);while(!que.empty()){        //int n = que.size();     //每循环一次都要重新计算vector<int> ans;        //存放每一层的结果for(int i = 0;i<n;i++){     //开始遍历TreeNode *node = que.front();       //一定要创建一个节点去存储队列的元素que.pop();                          //和前序遍历的思路差不多ans.push_back(node->val);           //先把元素弹出然后左右孩子加入队列if(node->left) que.push(node->left);        //if(node->right) que.push(node->right);}res.push_back(ans);                 //每遍历完一层就把当前的数组加入结果}    return res;}
};

http://www.dtcms.com/a/304142.html

相关文章:

  • React 图标库发布到 npm 仓库
  • 试用SAP BTP 02C:试用SAP HANA Schemas HDI Containers
  • 构建特定领域的大模型
  • OV IP证书如何满足PCI DSS要求
  • 网络通信基础(一)
  • 第十六章 Java基础-拼图小游戏
  • 测试自动化不踩坑:4 策略告别 “为自动化而自动化”
  • BERT和GPT和ELMO核心对比
  • vue3插槽详解
  • Python之禅
  • mac 字体遍历demo
  • 《林景媚与命运解放者》
  • OpenCV 学习探秘之四:从角点检测,SIFT/SURF/ORB特征提取,目标检测与识别,Haar级联分类人脸检测,再到机器学习等接口的全面实战应用与解析
  • MySQL(配置)——MariaDB使用
  • 2025北京师范大学数学分析考研试题
  • 15-C语言:第15~16天笔记
  • FreeRTOS在中断上下文中设置事件组,调度很慢的的解决方法
  • 智慧工地系统:科技如何重塑建筑现场?
  • macOS “Sploitlight“漏洞曝光:攻击者可窃取Apple Intelligence缓存数据
  • 用动态的观点看加锁
  • 新升级超值型系列32位单片机MM32G0005
  • C++类中动态内存分配注意手册
  • python新手,学习计划
  • 每日一题7.29
  • 当贝纯净版_海信ip811n海思mv320处理器安卓4.42及9.0主板优盘免拆刷机固件及教程
  • [Token]ALGM: 基于自适应局部-全局token合并的简单视觉Transformer用于高效语义分割, CVPR2024
  • 安卓逆向2-安卓刷机和获取root权限和安装LSPosed框架
  • 博物馆 VR 导览:图形渲染算法+智能讲解技术算法实现及优化
  • 想要批量提取视频背景音乐?FFmpeg 和转换器都安排上
  • 机器学习、深度学习与数据挖掘:三大技术领域的深度解析