栈-二叉树的中序遍历/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点:①从这个状态怎么传递到下一状态;②下一状态归来时,这一状态怎么应对下一状态所归来的结果。

相关推荐
小O的算法实验室4 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-5 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~5 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界5 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构
阿文的代码库5 小时前
一文读懂GROUP BY 1,2 VS GROUP BY column_1, column_2 的区别
算法
008爬虫实战录6 小时前
【码上爬】 题十:魔改算法 堆栈分析,找加密值过程详解
前端·python·算法
chao1898446 小时前
基于狮蚁群算法(ALO)的火电机组功能调度实现
人工智能·算法
Deep-w6 小时前
【MATLAB】含光伏 - 储能的家庭/工业微电网能量管理仿真研究
开发语言·算法·matlab
阿文的代码库6 小时前
换根技巧实例分析:最小高度树
算法·动态规划
dyxal6 小时前
Louvain 算法:让网络自己“报团取暖”的发现者
开发语言·算法