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

相关推荐
Hesionberger7 小时前
LeetCode98:验证二叉搜索树(多解)
java·开发语言·python·算法·leetcode·职场和发展
千寻girling7 小时前
周日那天参加的力扣周赛... —— 10号
java·javascript·c++·python·算法·leetcode·职场和发展
guygg887 小时前
基于 DWT 的盲数字水印实现(嵌入与提取)
算法
鱼子星_7 小时前
最短路问题【图论】
数据结构·算法·贪心算法·动态规划·图论
研究点啥好呢7 小时前
dji机器人SLAM算法工程师 面试题精选:10道高频考题+答案解析
c++·算法·机器人·slam·dji
君万7 小时前
【LeetCode每日一题】3. 无重复字符的最长子串 560. 和为 K 的子数组
算法·leetcode·golang·go
代码地平线7 小时前
【排序】C语言实现八大排序算法(含完整源码与性能测试)
c语言·算法·排序算法
承渊政道7 小时前
【贪心算法】(经典实战应用解析(一):柠檬水找零、将数组和减半的最少操作次数、最大数、摆动序列)
数据结构·c++·学习·算法·leetcode·贪心算法·排序算法
初心未改HD7 小时前
机器学习之支持向量机SVM详解
算法·机器学习·支持向量机
he___H7 小时前
子串----
java·数据结构·算法·leetcode