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

简介: 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;
    }
};

总结


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

相关文章
|
7月前
二叉树的几个递归问题
二叉树的几个递归问题
28 0
|
6天前
|
算法
递归算法:二叉树前序、中序、后序遍历解析与递归思想深度剖析
递归算法:二叉树前序、中序、后序遍历解析与递归思想深度剖析
43 0
|
9月前
|
算法
用递归的思想实现二叉树前、中、后序迭代遍历
用递归的思想实现二叉树前、中、后序迭代遍历
48 1
|
9月前
二叉树的遍历(递归And迭代)
二叉树的遍历(递归And迭代)
32 0
|
7月前
递归与非递归实现二叉树的前中后序遍历!!
递归与非递归实现二叉树的前中后序遍历!!
25 0
|
存储 算法
二叉树的前序/中序/后序遍历—采用递归与迭代两种方法实现嗷
二叉树的前序/中序/后序遍历—采用递归与迭代两种方法实现嗷
|
iOS开发
二叉树非递归前中后遍历
因为个人身体原因,本周都在医院住院治疗身体,身边没有电脑,只能分享一些这周看过的比较好的书籍内容。iPad上传csdn图片顺序会有误,看书的页码就好。
二叉树非递归前中后遍历
leetcode【二叉树—简单】 二叉树迭代遍历
leetcode【二叉树—简单】 二叉树迭代遍历
|
数据采集 算法
数据结构与算法—二叉树的层序、前序中序后序(递归、非递归)遍历
层序遍历。听名字也知道是按层遍历。我们知道一个节点有左右节点。而每一层一层的遍历都和左右节点有着很大的关系。也就是我们选用的数据结构不能一股脑的往一个方向钻,而左右应该均衡考虑。这样我们就选用队列来实现。
163 0
数据结构与算法—二叉树的层序、前序中序后序(递归、非递归)遍历