栈-二叉树的中序遍历/easy

二叉树的中序遍历

1、题目

给定一个二叉树的根节点 root ,返回 它的 中序 遍历

示例 1:

复制代码
输入:root = [1,null,2,3]
输出:[1,3,2]

示例 2:

复制代码
输入:root = []
输出:[]

示例 3:

复制代码
输入:root = [1]
输出:[1]

提示:

  • 树中节点数目在范围 [0, 100]
  • -100 <= Node.val <= 100

进阶: 递归算法很简单,你可以通过迭代算法完成吗?
Related Topics

  • 深度优先搜索
  • 二叉树

2、解题思路

1、明确树的递归遍历就是左 中 右,依次遍历

2、前中后序遍历的概念和适用场景

3、复杂度最优解示例

java 复制代码
    public List<Integer> inorderTraversal(TreeNode root) {
        if (Objects.isNull(root)) {
            return new ArrayList<>();
        }
        ArrayList<Integer> order  = new ArrayList<>();
        order.addAll(this.inorderTraversal(root.left));
        order.add(root.val);
        order.addAll(this.inorderTraversal(root.right));
        return order;
    }

4、抽象与扩展

递归算法的最终结果有2点:①递归方程;②终止条件

在思考递归算法时,要有递有归,不能一味按计算机的角度,一直往下传递,因为人脑处理问题的角度跟计算机不同,思考层次太深可能就绕不出来了。

建议是站在某一状态(或说某一层次)上,默认后续状态正常返回,也就是说只考虑2点:①从这个状态怎么传递到下一状态;②下一状态归来时,这一状态怎么应对下一状态所归来的结果。

相关推荐
咸鱼翻身小阿橙2 分钟前
高斯模糊降噪/磨皮算法降噪图像
前端·opencv·算法·webpack·c#
代码中介商8 分钟前
数据结构进阶(五):最短路径——Dijkstra 与 Floyd 算法
数据结构·算法
fengxin_rou10 分钟前
LeetCode链表经典五题:从相交到环形,双指针的妙用
算法·leetcode·链表
KaMeidebaby10 分钟前
卡梅德生物技术快报|抗原如何自己检测?FAdV-4 重组抗原制备与 ELISA 体系技术调试指南
前端·人工智能·物联网·算法·百度
却道天凉_好个秋14 分钟前
HEVC(二):如何实现并行处理
人工智能·算法·计算机视觉·hevc·瓦片技术·波前并行处理wpp
wayz1115 分钟前
Momentum:QQE(定量定性估计)技术指标详解
算法·金融·数据分析·量化交易·特征工程
Dontla16 分钟前
聚类找不到簇原因分析(聚类失败)(DBSCAN聚类算法、eps参数、Epsilon参数、最大允许距离)
算法·数据挖掘·聚类
写代码写到手抽筋8 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.9 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz119 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程