day13|二叉树理论

一、二叉树的定义

java 复制代码
//定义一个二叉树:使用链式存储
public class TreeNode {

	int val; // 节点的值
	TreeNode left; // 左子节点
	TreeNode right; // 右子节点
	
	public TreeNode() {
	}
	
	// 构造函数,初始化节点值
	public TreeNode(int val){
	    this.val=val;
	}
	
	// 构造函数,初始化节点值、左子节点和右子节点
	public TreeNode(int val, TreeNode left, TreeNode right) {
	    this.val = val;
	    this.left = left;
	    this.right = right;
	}

}

二、前序遍历

bash 复制代码
package com.thirteenday.tree;

import java.util.ArrayList;
import java.util.List;


//前序遍历
/**
 * 递归三部曲:
 *  1、确定递归函数的参数和返回值
 *  2、确定递归终止条件
 *  3、确定单层递归的逻辑
 */
public class PreorderTraversal {
    /**
     * 1、确定递归函数的参数和返回值
     * @param root  树的根节点
     * @param result  将遍历的结果放在集合中
     */
    private static void preorder(TreeNode root , List<Integer> result){

        //2、确定递归终止条件
        if (root == null){
            return;
        }
        //3、确定单层递归的逻辑:前序遍历:根左右
        result.add(root.val); //根
        preorder(root.left,result);//左
        preorder(root.right,result); //右

    }
    public static List<Integer> preorderTraversal(TreeNode root){
        ArrayList<Integer> result = new ArrayList<>();
        preorder(root,result);
        return result;
    }

    public static void main(String[] args) {
        TreeNode root = new TreeNode(1, new TreeNode(2, new TreeNode(4), new TreeNode(5)), new TreeNode(3, new TreeNode(6), new TreeNode(7)));
        List<Integer> list = preorderTraversal(root);
        list.stream().forEach( e -> System.out.println(e+" "));
    }

}

三、中序遍历

bash 复制代码
package com.thirteenday.tree;

import java.util.ArrayList;
import java.util.List;

//中序遍历
public class InorderTraversal {


    /**
     * 1、确定递归函数的参数和返回值
     * @param root  树的根节点
     * @param result  将遍历的结果放在集合中
     */
    private static void preorder(TreeNode root , List<Integer> result){

        //2、确定递归终止条件
        if (root == null){
            return;
        }
        //3、确定单层递归的逻辑:中序遍历:左根右

        preorder(root.left,result);//左
        result.add(root.val); //根
        preorder(root.right,result); //右

    }

    public static List<Integer> inorderTraversal(TreeNode root){
        ArrayList<Integer> result = new ArrayList<>();
        preorder(root,result);
        return result;
    }


    public static void main(String[] args) {
        TreeNode root = new TreeNode(1, new TreeNode(2, new TreeNode(4), new TreeNode(5)), new TreeNode(3, new TreeNode(6), new TreeNode(7)));
        List<Integer> list = inorderTraversal(root);
        list.stream().forEach( e -> System.out.println(e+" "));
    }
}

四、后序遍历

bash 复制代码
//后序遍历
public class PostorderTraversal {
    /**
     * 1、确定递归函数的参数和返回值
     * @param root  树的根节点
     * @param result  将遍历的结果放在集合中
     */
    private static void preorder(TreeNode root , List<Integer> result){

        //2、确定递归终止条件
        if (root == null){
            return;
        }
        //3、确定单层递归的逻辑:后序遍历:左右根

        preorder(root.left,result);//左
        preorder(root.right,result); //右
        result.add(root.val); //根

    }

    public static List<Integer> postorderTraversal(TreeNode root){
        ArrayList<Integer> result = new ArrayList<>();
        preorder(root,result);
        return result;
    }


    public static void main(String[] args) {
        TreeNode root = new TreeNode(1, new TreeNode(2, new TreeNode(4), new TreeNode(5)), new TreeNode(3, new TreeNode(6), new TreeNode(7)));
        List<Integer> list = postorderTraversal(root);
        list.stream().forEach( e -> System.out.println(e+" "));
    }
}
相关推荐
ExRoc36 分钟前
蓝桥杯真题 - 填充 - 题解
c++·算法·蓝桥杯
利刃大大1 小时前
【二叉树的深搜】二叉树剪枝
c++·算法·dfs·剪枝
天乐敲代码3 小时前
JAVASE入门九脚-集合框架ArrayList,LinkedList,HashSet,TreeSet,迭代
java·开发语言·算法
十年一梦实验室3 小时前
【Eigen教程】矩阵、数组和向量类(二)
线性代数·算法·矩阵
Kent_J_Truman3 小时前
【子矩阵——优先队列】
算法
快手技术5 小时前
KwaiCoder-23BA4-v1:以 1/30 的成本训练全尺寸 SOTA 代码续写大模型
算法·机器学习·开源
一只码代码的章鱼5 小时前
粒子群算法 笔记 数学建模
笔记·算法·数学建模·逻辑回归
小小小小关同学5 小时前
【JVM】垃圾收集器详解
java·jvm·算法
圆圆滚滚小企鹅。5 小时前
刷题笔记 贪心算法-1 贪心算法理论基础
笔记·算法·leetcode·贪心算法
Kacey Huang5 小时前
YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战第十三天|YOLOv3实战、安装Typora
人工智能·算法·yolo·目标检测·计算机视觉