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

相关推荐
oo哦哦14 小时前
搜索矩阵系统的最短路密码:用Dijkstra算法和网络流理论,解释为什么你做了1000个关键词,流量还不如别人30个
网络·算法·矩阵
Matlab程序猿小助手14 小时前
【MATLAB源码-第319期】基于matlab的帝王蝶优化算法(MBO)无人机三维路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab
图码14 小时前
二分查找进阶:如何在有序数组中快速找到Upper Bound?
数据结构·算法·面试·分类·柔性数组
试剂界的爱马仕14 小时前
《古董局·终局5:潮生》第 2 章:镜子的天赋
大数据·人工智能·算法
Cthy_hy14 小时前
树状数组(BIT)进阶:差分优化实现区间修改、区间查询
数据结构·python·算法
YsyaaabB15 小时前
ACM 模式通用代码模板
java·c++·python·算法
ComputerInBook15 小时前
Euclid 几何变换——仿射(affine)变换
算法·仿射变换·几何变换
一只叁木Meow16 小时前
电商 SKU 选择器:用算法实现优雅的用户交互
前端·javascript·算法
代码中介商16 小时前
红黑树完全指南:从五条性质到完整插入删除实现
数据结构·算法
JieE21216 小时前
反转链表:从双指针到递归,吃透链表反转的核心逻辑
javascript·算法