-
题目
java给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 -
示例
java示例 1 输入:root = [1,null,2,3] 输出:[1,3,2] 示例 2: 输入:root = [] 输出:[] 示例 3: 输入:root = [1] 输出:[1] -
解题思路
- 方法一:递归。
- 方法二:循环。
- 使用栈保存根节点。
- 每次从栈中取出当前根节点,并将其左右子节点,加入栈中。
-
代码(Java)
java// 方法一 class Solution { public List<Integer> inorderTraversal(TreeNode root) { List<Integer> res = new ArrayList<>(); midTrav(res, root); return res; } public Integer midTrav(List<Integer> res, TreeNode root) { if (root != null) { Integer left = midTrav(res, root.left); if (left != null) { res.add(left); } res.add(root.val); Integer right = midTrav(res, root.right); if (right != null) { res.add(right); } } return null; } }javaclass Solution { public List<Integer> inorderTraversal(TreeNode root) { List<Integer> res = new ArrayList<>(); if (root == null) { return res; } Stack<TreeNode> stack = new Stack<TreeNode>(); while (root != null || !stack.isEmpty()) { if (root != null) { stack.push(root); root = root.left; } else { root = stack.pop(); res.add(root.val); root = root.right; } } return res; } }
LeetCode94 二叉树的中遍历
biglxl2024-03-10 19:35
相关推荐
naruto_lnq32 分钟前
分布式系统安全通信Jasmine_llq1 小时前
《P3157 [CQOI2011] 动态逆序对》爱吃rabbit的mq1 小时前
第09章:随机森林:集成学习的威力(❁´◡`❁)Jimmy(❁´◡`❁)2 小时前
Exgcd 学习笔记YYuCChi3 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)不能隔夜的咖喱3 小时前
牛客网刷题(2)VT.馒头3 小时前
【力扣】2721. 并行执行异步函数进击的小头3 小时前
实战案例:51单片机低功耗场景下的简易滤波实现咖丨喱5 小时前
IP校验和算法解析与实现罗湖老棍子5 小时前
括号配对(信息学奥赛一本通- P1572)