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;
    }
};

总结


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

相关文章
地震监测系统
地震监测系统
|
前端开发 JavaScript Java
Spring Boot整合Thymeleaf模板引擎
Spring Boot整合Thymeleaf模板引擎
270 0
Spring Boot整合Thymeleaf模板引擎
【算法提高——第二讲】搜索(1)
【算法提高——第二讲】搜索(1)
【算法提高——第二讲】搜索(1)
|
2天前
|
数据采集 人工智能 安全
|
11天前
|
云安全 监控 安全
|
3天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1014 151
|
3天前
|
编解码 人工智能 机器人
通义万相2.6,模型使用指南
智能分镜 | 多镜头叙事 | 支持15秒视频生成 | 高品质声音生成 | 多人稳定对话
|
16天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1709 9
|
8天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
652 152