• 剑指offer之树专题


    1、层次遍历(bfs)

    非递归

    每一层是按照从左到右的顺序

    为了满足先遍历先出采用队列的数据结构,队列里面存放我们遍历过的节点

     

    首先根节点入队,当队列不空时,出队队首元素并打印相应节点的内容。如果出队的节点有左孩子或者右孩子,则入队左孩子节点或者右孩子节点,如此循环

    1. class Solution
    2. {
    3. public:
    4. vector<int> bfs(TreeNode *root)//返回的是一个int的vector
    5. {
    6. vector<int>res;
    7. queue<TreeNode *>q;//辅助队列
    8. if(root==NULL)return res;//空树返回空
    9. q.push(root);//将根节点入队
    10. while(!q.empty())
    11. {
    12. //入队
    13. res.push_back(q.front()->val);
    14. if(q.front()->left!=NULL)
    15. {
    16. q.push(q.front()->left);
    17. }
    18. if(q.front()->right!=NULL)
    19. {
    20. q.push(q.front()->right);
    21. }
    22. // 出队
    23. q.pop();//弹出第一个元素
    24. }
    25. return res;//只有最后才会执行这个
    26. }
    27. };

    2、深度优先遍历(递归)

    按照遍历顺序将节点存放在容器中

    遍历就像我们走路上有很多坑,一旦掉进去就是很多层,只有到底才能开始慢慢向上攀爬,小事件结束就是我们的梯子

     1、确定终止条件

    如果当层遍历的节点为空的话,就是结束本层,返回上一层

    if(cur == NULL) return;

     2、单层递归的逻辑:前序是中、左、右

    1. vec.push_back(cur ->val);//中间节点插入
    2. traversal(cur ->left,vec);//
    3. traversal(cur ->right,vec);//

    完整代码

    1. lass Solution {
    2. public:
    3. void preorder(TreeNode *root, vector<int> &res) {
    4. if (root == nullptr) return;//终止条件
    5. res.push_back(root->val); //
    6. preorder(root->left, res); //
    7. preorder(root->right, res); //
    8. }
    9. vector<int> preorderTraversal(TreeNode *root) {
    10. vector<int> res;
    11. preorder(root, res);
    12. return res;
    13. }
    14. };
    15. 8

    非递归

    利用栈

    访问到空节点的话,就会跳到上一层,然后将栈顶出

    我们栈是先进后出

    前序是中,右、左()

    中序:左、中、右()

    后续:中、左、右

    //前序代码

    1. class Solution {
    2. public:
    3. vector<int> preorderTraversal(TreeNode* root) {
    4. vector<int> res;
    5. stack<TreeNode*> s;
    6. if(root == nullptr) return res;
    7. s.push(root); //压入根结点
    8. while (!s.empty()){ //入栈是 根右左
    9. TreeNode* node = s.top(); s.pop();
    10. res.push_back(node->val); //
    11. if (node->right) stk.push(node->right); //
    12. if (node->left) stk.push(node->left); //
    13. }
    14. return res;
    15. }
    16. };

  • 相关阅读:
    mysql基础部分第一次复习(1-8章,到聚合函数)
    面试官喜欢问Nacos原理?直接把这篇文章甩给他!
    16-Linux磁盘管理
    二分法-数据类型定义导致的内存超限
    【Linux基础】Linux基本指令(二)
    796. 子矩阵的和(二维前缀和)
    【华为OD机试真题 python】 城市聚集度【2022 Q4 | 200分】
    spring整合struts2 以及 会遇到的问题
    文本变成文本路径图 保存txt
    SpringSecuity和Shiro区别
  • 原文地址:https://blog.csdn.net/qq_43448818/article/details/126604126