⚡️94. 二叉树的中序遍历⚡️
给定一个二叉树的根节点 root ,返回它的 中序 遍历。
示例 1:
输入:root = [1,null,2,3]
输出:[1,3,2]
示例 2:
输入:root = []
输出:[]
示例 3:
输入:root = [1]
输出:[1]
示例 4:
输入:root = [1,2]
输出:[2,1]
示例 5:
输入:root = [1,null,2]
输出:[1,2]
提示:
树中节点数目在范围 [0, 100] 内
-100 <= Node.val <= 100
进阶: 递归算法很简单,你可以通过迭代算法完成吗?
⚡️分析⚡️
1.递归方法,标准中序遍历算法,不多解释
代码如下:
/**
* Definition for a binary tree node.
* function TreeNode(val, left, right) {
* this.val = (val===undefined ? 0 : val)
* this.left = (left===undefined ? null : left)
* this.right = (right===undefined ? null : right)
* }
*/
/**
* @param {TreeNode} root
* @return {number[]}
*/
var inorderTraversal = function(root) {
const res = [];
const rec = (root)=>{
if(!root)return;
rec(root.left);
res.push(root.val);
rec(root.right);
}
rec(root);
return res;
};
算法效率如图:
2.迭代方法,笔试的正常思路,先对结点的左边结点全部入队,然后直到左结点空了后,弹出栈顶元素并打印,然后把p指针指向栈顶元素右结点即可,让右结点继续重复上述动作。
代码如下:
/**
* Definition for a binary tree node.
* function TreeNode(val, left, right) {
* this.val = (val===undefined ? 0 : val)
* this.left = (left===undefined ? null : left)
* this.right = (right===undefined ? null : right)
* }
*/
/**
* @param {TreeNode} root
* @return {number[]}
*/
var inorderTraversal = function(root) {
const stack = [];
const res = [];
let p = root;
while(stack.length || p){
while(p){
stack.push(p);
p = p.left;
}
const now = stack.pop();
res.push(now.val);
p = now.right;
}
return res;
};
算法效率如图:
觉得该篇文章有用的请不要忘记忘记点击右下角的大拇指~
欢迎大家关注我的公众号:Smooth前端成长记录
公众号正在努力更新CSDN博客内容,想方便阅读博客的C友可以来关注我的公众号以便获得更优良的阅读体验~