【手把手带你刷好题】—— 51.二叉树的层序遍历 II(BFS)

举报
安然无虞 发表于 2022/05/26 23:09:15 2022/05/26
【摘要】 【前言】 今天是刷题打卡第51天! 加油鸭伙伴们。   原题:二叉树的层序遍历 II (BFS) 原题链接:力扣  题目描述:   示例:   思路: 大家先看一下层序遍历这篇博文,直接将最后存放到二维数组中的数据反转即可。 【手把手带你刷好题...

【前言】

今天是刷题打卡第51天!

加油鸭伙伴们。

 

原题:二叉树的层序遍历 II (BFS)

原题链接:力扣 

题目描述:

 

示例:

 

思路:

大家先看一下层序遍历这篇博文,直接将最后存放到二维数组中的数据反转即可。

【手把手带你刷好题】—— 48.二叉树的层序遍历(BFS)_安然无虞的博客-CSDN博客【前言】今天是刷题打卡第42天!早成者未必有成,晚达者未必不达。一起都还来得及,加油哦。原题:二叉树的层序遍历(BFS)题目描述:给你一个二叉树,请你返回其按层序遍历得到的节点值。 (即逐层地,从左到右访问所有节点)。示例:...https://blog.csdn.net/weixin_57544072/article/details/121716957

代码执行:


  
  1. /**
  2. * Definition for a binary tree node.
  3. * struct TreeNode {
  4. * int val;
  5. * TreeNode *left;
  6. * TreeNode *right;
  7. * TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8. * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9. * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10. * };
  11. */
  12. class Solution {
  13. public:
  14. vector<vector<int>> levelOrderBottom(TreeNode* root) {
  15. //定义一个队列
  16. queue<TreeNode*>q;
  17. //定义一个二维数组用于返回结果
  18. vector<vector<int> >ans;
  19. //先将根节点入队
  20. if(root)
  21. q.push(root);
  22. while(!q.empty())
  23. {
  24. //定义一个一维数组用于存放每一层节点的值
  25. vector<int>temp;
  26. int n = q.size();//队列的长度
  27. for(int i = 0; i < n; i++)
  28. {
  29. //访问队首元素
  30. TreeNode* t = q.front();
  31. //队首元素出队
  32. q.pop();
  33. //将队首元素的值存放到一维数组中
  34. temp.push_back(t->val);
  35. //访问左子树
  36. if(t->left)
  37. q.push(t->left);
  38. //访问右子树
  39. if(t->right)
  40. q.push(t->right);
  41. }
  42. ans.push_back(temp);
  43. }
  44. reverse(ans.begin(), ans.end());//反转二维数组中的结果
  45. return ans;
  46. }
  47. };

结语

今天是刷题打卡第51天!

加油吧少年。 

  

文章来源: bit-runout.blog.csdn.net,作者:安然无虞,版权归原作者所有,如需转载,请联系作者。

原文链接:bit-runout.blog.csdn.net/article/details/121869790

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。