Leetcode 二叉树中序遍历 前序遍历 后序遍历(递归)

中序遍历:

java 复制代码
/**
 * 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<Integer> inorderTraversal(TreeNode root) {
        List<Integer> tree=new ArrayList<>(); //建立一个动态数组
        inorder(root,tree); //调用递归函数,实参
        return tree;

    }

    public void inorder(TreeNode root, List<Integer> tree){
        // TreeNode root,List<Interger> tree都是传入的形参
        if(root==null){
            return;
        }
        inorder(root.left,tree);  //遍历左子树
        tree.add(root.val); //将当前值加入动态数组中
        inorder(root.right,tree); //遍历右子树

    }
    
}

前序遍历

java 复制代码
class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
            List<Integer> tree =new ArrayList<Integer>();
            PreOrder(root,tree);
            return tree;

    }

    public void PreOrder(TreeNode root, List<Integer> tree){
        if(tree==null){
        return;}
        tree.add(root.val);
        PreOrder(root.left,tree);
        PreOrder(root.right,tree);
    


    }





}

}

后序遍历

java 复制代码
class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
            List<Integer> tree =new ArrayList<Integer>();
            PostOrder(root,tree);
            return tree;

    }

    public void PostOrder(TreeNode root, List<Integer> tree){
        if(tree==null){
        return;}
        PostOrder(root.left,tree);
        PostOrder(root.right,tree);
        tree.add(root.val);
    


    }





}

}
相关推荐
JieE2124 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言