文章图片
递归版:
class Solution {
public List inorderTraversal(TreeNode root) {
List res = new ArrayList<>();
if (root == null) return res;
help(root, res);
return res;
}
public void help(TreeNode root, List list) {
if (root == null) return ;
help(root.left, list);
list.add(root.val);
help(root.right, list);
}
}
非递归版:
思路:
用栈进行模拟,当栈非空或者root不为空的时候,就一直判断
如果root为空,说明左孩子空了,判断pop()节点,然后走右子树;否则,一直往栈里面扔左孩子
/**
* Definition for a binary tree node.
* public class TreeNode {
*int val;
*TreeNode left;
*TreeNode right;
*TreeNode() {}
*TreeNode(int val) { this.val = val;
}
*TreeNode(int val, TreeNode left, TreeNode right) {
*this.val = val;
*this.left = left;
*this.right = right;
*}
* }
*/
class Solution {
public List inorderTraversal(TreeNode root) {
// 非递归
List res = new ArrayList<>();
Stack stack = new Stack<>();
while (stack.size() > 0 || root != null) {
if (root == null) {
TreeNode node = stack.pop();
res.add(node.val);
if (node.right != null) root = node.right;
} else {
stack.push(root);
root = root.left;
}
}
return res;
}
}
【leetcode|LeetCode 94. 二叉树的中序遍历】
推荐阅读
- 动态规划|LeetCode 300.最长递归子序列
- 数据结构与算法|4 单循环链表解决约瑟夫问题
- C语言|C语言求水仙花数
- C语言|C语言求输入字符的字母和数字个数
- 关于滑动时间窗口算法
- leetcode|46. 全排列
- 菜鸟刷题|蓝桥杯每日一题——最大字段和问题(动态规划)
- 算法|leetcode378. 有序矩阵中第 K 小的元素
- 算法|104 二叉树的最大深度(Java)