Day14——二叉树的前中后序遍历(迭代&&递归)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: Day14——二叉树的前中后序遍历(迭代&&递归)

前言


今日文案:

仰望天空时,什么都比你高,你会自卑;俯视大地时,什么都比你低,你会自负;只有放宽视野,把天空和大地尽收眼底,才能在苍穹泛土之间找到你真正的位置。无须自卑,不要自负,坚持自信。

递归真的很难用文字表述,我只能写一点我自己看得懂的内容了~

一、二叉树前序遍历


题目来源:

力扣

解题思路(迭代):


所谓前序,就是中左右得遍历二叉树。

保留中值后,全部优先解析左边先,然后回头解析右边。

class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) {
            vector<int> ans;            //创建一个存放答案的数组
        stack<TreeNode*> st;            //创建一个栈
        if(root==0)
        return ans;
        st.push(root);                //先存入头节点
        while(!st.empty())
        {
            TreeNode*node=st.top();        //弹出第一个元素来使用
            st.pop();                        
            ans.push_back(node->val);    //保存值,此时的值是中值
            if(node->right)                //保存左右值,因为栈的特点,后进先出,先解析左边
            st.push(node->right);
            if(node->left)
            st.push(node->left);
        }
        return ans;
    }
};

解题思路(递归)


class Solution {
public:
    void mysearch(TreeNode*cur,vector<int> &ans)
    {
        if(cur==0)
        return;
        ans.push_back(cur->val);        //先插入中值
        mysearch(cur->left,ans);        //然后解析左
        mysearch(cur->right,ans);        //解析右
    }
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> ans;
        mysearch(root,ans);
        return ans;
    }
}

因为使用递归,三种遍历方式都差不多,只需要改变一下位置就行。

二、二叉树中序


解题思路:


先一股脑往左边差到最深,把左节点全部放进栈,然后解析栈,之后保留中值,然后放入右节点解析。

中、后序两者非常相像,只是顺序问题。


class Solution {
public:
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> result;
        stack<TreeNode*> st;
        TreeNode* cur = root;
        while (cur != NULL || !st.empty()) {
            if (cur != NULL) { // 指针来访问节点,访问到最底层
                st.push(cur); // 将访问的节点放进栈
                cur = cur->left;                // 左
            } else {
                cur = st.top(); // 从栈里弹出的数据,就是要处理的数据(放进result数组里的数据)
                st.pop();
                result.push_back(cur->val);     // 中
                cur = cur->right;               // 右
            }
        }
        return result;
    }
};

总结


疲于奔命,二叉树的递归和迭代真的非常精妙一定要多画图理解。

相关文章
二叉树的几个递归问题
二叉树的几个递归问题
46 0
|
6天前
|
存储 算法
后序遍历的递归和非递归实现有何区别?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
|
5月前
|
存储 算法 编译器
技术经验解读:二叉树的遍历:先序中序后序遍历的递归与非递归实现及层序遍历
技术经验解读:二叉树的遍历:先序中序后序遍历的递归与非递归实现及层序遍历
38 0
|
5月前
|
存储 SQL 算法
LeetCode 题目 94:五种算法递归|迭代|莫里斯|线索二叉树|栈的迭代二叉树 实现中序遍历
LeetCode 题目 94:五种算法递归|迭代|莫里斯|线索二叉树|栈的迭代二叉树 实现中序遍历
|
算法
用递归的思想实现二叉树前、中、后序迭代遍历
用递归的思想实现二叉树前、中、后序迭代遍历
68 1
|
6月前
搜索二叉树(二叉搜索树)的实现(递归与非递归)
搜索二叉树(二叉搜索树)的实现(递归与非递归)
二叉树的遍历(递归And迭代)
二叉树的遍历(递归And迭代)
48 0
递归与非递归实现二叉树的前中后序遍历!!
递归与非递归实现二叉树的前中后序遍历!!
49 0
|
存储 算法
二叉树的前序/中序/后序遍历—采用递归与迭代两种方法实现嗷
二叉树的前序/中序/后序遍历—采用递归与迭代两种方法实现嗷
|
iOS开发
二叉树非递归前中后遍历
因为个人身体原因,本周都在医院住院治疗身体,身边没有电脑,只能分享一些这周看过的比较好的书籍内容。iPad上传csdn图片顺序会有误,看书的页码就好。
二叉树非递归前中后遍历