• 剑指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. };

  • 相关阅读:
    【Express.js】软件构建
    c 利用socket传输大文件
    JVM常用概念之扁平化堆容器
    Java集合或Map中元素排序及过滤
    [云原生] [kubernetes] Kubesphere下的DevOps / (CI/CD)
    开源大模型正在“杀死”闭源?
    公众号涨粉思路
    欧科云链研究院:从香港SFC最新文件看链上交易合规必备之选
    牛客刷题<14>键盘编码电路
    MySql(19)视图
  • 原文地址:https://blog.csdn.net/qq_43448818/article/details/126604126