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);
    


    }





}

}
相关推荐
YGGP33 分钟前
【Golang】LeetCode 128. 最长连续序列
leetcode
你撅嘴真丑7 小时前
第九章-数字三角形
算法
uesowys7 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder7 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮7 小时前
AI 视觉连载1:像素
算法
智驱力人工智能8 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥8 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风8 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風9 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT069 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法