经典重庆网站,黑色企业网站,太月星网站建设,wordpress目录94. 二叉树的中序遍历
难度#xff1a;简单
题目
给定一个二叉树的根节点 root #xff0c;返回 它的 中序 遍历 。
示例 1#xff1a;
输入#xff1a;root [1,null,2,3]
输出#xff1a;[1,3,2]示例 2#xff1a;
输入#xff1a;root []
输出#xff1a;[]示…94. 二叉树的中序遍历
难度简单
题目
给定一个二叉树的根节点 root 返回 它的 中序 遍历 。
示例 1
输入root [1,null,2,3]
输出[1,3,2]示例 2
输入root []
输出[]示例 3
输入root [1]
输出[1]提示
树中节点数目在范围 [0, 100] 内-100 Node.val 100
进阶: 递归算法很简单你可以通过迭代算法完成吗
个人题解
方法一递归
递归最简单的前中后序遍历方式
/*** 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 ListInteger inorderTraversal(TreeNode root) {ListInteger result new ArrayList();process(result, root);return result;}public void process(ListInteger result, TreeNode node) {if (node null) {return;}process(result, node.left);result.add(node.val);process(result, node.right);}
}方法二迭代
/*** 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 ListInteger inorderTraversal(TreeNode root) {ListInteger res new ArrayList();DequeTreeNode stack new LinkedList();TreeNode cur root;while (cur ! null || !stack.isEmpty()) {while (cur ! null) {stack.push(cur);cur cur.left;}cur stack.pop();res.add(cur.val);cur cur.right;}return res;}
}