leetcode94. 二叉树的中序遍历,递归法+迭代法。附带前序遍历方法
创始人
2024-12-28 20:37:02
0

leetcode94. 二叉树的中序遍历

给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。
示例 1:
在这里插入图片描述
输入:root = [1,null,2,3]
输出:[1,3,2]

示例 2:
输入:root = []
输出:[]

示例 3:
输入:root = [1]
输出:[1]

一般思路:我们当初在学数据结构时的方法就是递归解决。先递归遍历左子树,然后递归访问根节点,最后递归遍历右子树。所谓中序、先序、后序的递归遍历只需要更改
res.push_back(node->val);
的位置即可。
完整代码如下:

class Solution { public:     void inorder(TreeNode* node,vector &res)     {         if(!node) return ;         inorder(node->left,res);         res.push_back(node->val);         inorder(node->right,res);         return ;     }     vector inorderTraversal(TreeNode* root) {     vector res;     if(root==NULL) return res;     inorder(root,res);     return res;     } }; 

我们可以将递归改写成迭代。
所谓迭代法,我们要使用到栈数据结构。具体来说,中序遍历就是把左子树的所有节点存入栈中,到底后再一个个弹出来,弹出来的过程中每弹出来一个,把根遍历后,把根的右子树也都存入栈中

class Solution { public:     vector inorderTraversal(TreeNode* root) {     stack stk;     vector res;     while(root!=nullptr || !stk.empty())     {         while(root!=nullptr)         {             stk.push(root);             root=root->left;         }         root=stk.top();         stk.pop();         res.push_back(root->val);         root=root->right;     }     return res;     } }; 

迭代法里比较难理解的是对右子树的处理,当左子树节点都被存入栈中之后,我们弹出一个节点,将其放入结果数组后,再处理当前节点的右节点(如果有的话),因为当前节点的右节点也可能存在左节点,如果有的话这些节点应该是在栈中其他节点之前被遍历的。

二叉树的前序遍历迭代法的逻辑也是这样,唯一区别每次节点入栈之前先遍历到结果数组里。

代码如下:

class Solution { public:     vector preorderTraversal(TreeNode* root) {         vector res;         if (root == nullptr) {             return res;         }          stack stk;         TreeNode* node = root;         while (!stk.empty() || node != nullptr) {             while (node != nullptr) {                 res.push_back(node->val);                 stk.push(node);                 node = node->left;             }             node = stk.top();             stk.pop();             node = node->right;         }         return res;     } };  

后序遍历迭代法相对将要难一些,我们之后再说。

相关内容

热门资讯

来临!九九山城辅助免费(辅助)... 来临!九九山城辅助免费(辅助)果然是有辅助辅助器(有挂细节)-哔哩哔哩来临!九九山城辅助免费(辅助)...
第五分钟了解!安卓闲逸辅助,新... 第五分钟了解!安卓闲逸辅助,新玉海楼游戏茶苑,绝活儿教程(有挂分析)-哔哩哔哩1、进入游戏-大厅左侧...
据通报!中至江西插件(辅助)真... 据通报!中至江西插件(辅助)真是是真的辅助下载(确实有挂)-哔哩哔哩1、打开软件启动之后找到中间准星...
十分钟了解!途游四川小程序脚本... 十分钟了解!途游四川小程序脚本,功夫川麻老是输什么情况,阶段教程(有挂透明挂)-哔哩哔哩1、进入游戏...
一直以来!微友辅助器免费版v2... 一直以来!微友辅助器免费版v2.0(辅助)确实有辅助app(有挂教程)-哔哩哔哩小薇(辅助器软件下载...
4分钟了解!皇豪互娱科技软件,... 4分钟了解!皇豪互娱科技软件,人皇大厅控制牌型,绝活教程(果真有挂)-哔哩哔哩1、上手简单,内置详细...
第八分钟了解!途游四川小程序有... 第八分钟了解!途游四川小程序有挂吗,新道游游戏辅助器安装包,经验教程(有挂辅助)-哔哩哔哩1、完成新...
据权威媒体报道!余干六副真有辅... 据权威媒体报道!余干六副真有辅助吗(辅助)确实真的有辅助插件(有挂秘笈)-哔哩哔哩一、余干六副真有辅...
4分钟了解!禅游科技辅助,欢乐... 4分钟了解!禅游科技辅助,欢乐对决辅助菜单,窍要教程(了解有挂)-哔哩哔哩暗藏猫腻,小编详细说明欢乐...
现就发布提示!来来拼十辅助免费... 现就发布提示!来来拼十辅助免费辅助(辅助)好像存在有辅助神器(有挂技巧)-哔哩哔哩1、来来拼十辅助免...