码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 力扣(103、236、104)


    103. 二叉树的锯齿形层序遍历

    题目大意:将原先的层次遍历改为蛇形遍历,那么我们需要在102. 二叉树的层序遍历的基础上进行改进,首先蛇形走位(先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)

    让我们想到设置 bool 值进行左右方向控制遍历方向,使其进入队列,但这样不如直接使用双端队列。

    如果是奇数行正序进入队列,偶数行逆序进入----》奇数行元素从队头插入,偶数行从队尾插入。

    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),
    10. * right(right) {}
    11. * };
    12. */
    13. class Solution {
    14. public:
    15. vectorint>> ans;
    16. vectorint>> zigzagLevelOrder(TreeNode* root) {
    17. if (!root)
    18. return ans;
    19. TreeNode* visited=root;
    20. queue q;
    21. bool left = 1; // 控制左右孩子进入顺序
    22. q.push(visited);
    23. while (!q.empty()) {
    24. deque<int> levelList;
    25. int cursize = q.size();
    26. // ans.push_back(vector());
    27. for (int i = 0; i < cursize; i++) {
    28. q.pop();
    29. if (left)
    30. levelList.push_back(visited->val);
    31. else
    32. levelList.push_front(visited->val);
    33. if (visited->left)
    34. q.push(visited->left);
    35. if (visited->right)
    36. q.push(visited->right);
    37. visited = q.front();
    38. }
    39. left = !left;
    40. ans.emplace_back(vector<int>{levelList.begin(), levelList.end()});
    41. }
    42. return ans;
    43. }
    44. };

    下面来两道递归题目,树这块递归题目很多

     

    104. 二叉树的最大深度 

    1.确定递归函数的参数和返回值:参数就是传入树的根节点,返回就返回这棵树的深度,所以返回值为int类型。

    2.确定终止条件:如果为空节点的话,就返回0,表示高度为0。

    3.确定单层递归的逻辑:先求它的左子树的深度,再求右子树的深度,最后取左右深度最大的数值 再+1 (加1是因为算上当前中间节点)就是目前节点为根节点的树的深度。

    1. class Solution {
    2. public:
    3. int ans=0;
    4. int maxDepth(TreeNode* root) {//dfs
    5. if(!root) return 0;
    6. ans=max(maxDepth(root->left),maxDepth(root->right));
    7. return ans+1;
    8. }
    9. };

    236. 二叉树的最近公共祖先 

    1. class Solution {
    2. public:
    3. TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
    4. if(p==root||q==root||!root) return root;
    5. TreeNode *left=lowestCommonAncestor(root->left,p,q);
    6. TreeNode *right=lowestCommonAncestor(root->right,p,q);
    7. if(!left) return right;
    8. if(!right) return left;
    9. return root;
    10. }
    11. };

     

  • 相关阅读:
    数据结构之顺序查找
    【2023,学点儿新Java-42】赋值运算符 及其 基础练习(含整体分析解释,适合小白学习哦)| 复合赋值操作符:“+=“、“++“、“*=“的综合应用
    剑指Offer 05.替换空格
    docker去掉sudo权限方法
    香港服务器运行不正常原因简析
    国际视频编解码标准提案下载地址
    【爬坑之路一】windows系统下更新升级node版本【亲测有效】
    Excel 自动提取某一列不重复值
    AcWing 4505. 最大子集
    麦芽糖-聚乙二醇-顺铂 cisplatin-PEG-maltose
  • 原文地址:https://blog.csdn.net/m0_67403773/article/details/136709146
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号