当前位置: 首页 > news >正文

5道真题训练|学会了二叉树的前世今生

很多朋友都问我学完基础知识以后怎样提高编程水平?当然是刷题啦!很多小伙伴都在纠结从哪里开始,今天给大家推荐一个身边朋友都在使用的刷题网站:点击进入牛客网刷题吧!

在这里插入图片描述

今天是Java进阶刷题的第二天,结合经典算法学习Java语法!

文章目录

  • 👉第一题:二叉树的前序遍历
    • 题目描述
    • 示例
    • 题解
  • 👉第二题:二叉树的中序遍历
    • 题目描述
    • 示例
    • 题解
  • 👉第三题:二叉树的后序遍历
    • 题目描述
    • 示例
    • 题解
  • 👉第四题:求二叉树的层序遍历
    • 示例
    • 题解
  • 👉第五题:二叉树的最大深度
    • 题目描述
    • 题解
  • 总结,刷题经验分享

👉第一题:二叉树的前序遍历

题目描述

给你二叉树的根节点 root ,返回它节点值的 前序 遍历。

数据范围:二叉树的节点数量满足 1 \le n \le 100 \1≤n≤100  ,二叉树节点的值满足 1 \le val \le 100 \1≤val≤100  ,树的各节点的值各不相同

示例1:
在这里插入图片描述

示例

输入:{1,#,2,3}
返回值:[1,2,3]

题解

import java.util.*;
public class Solution {
    public void preorder(List<Integer> list, TreeNode root){
        //遇到空节点则返回
        if(root == null)
            return;
        //先遍历根节点
        list.add(root.val);
        //再去左子树
        preorder(list, root.left);
        //最后去右子树
        preorder(list, root.right);
    }
     
    public int[] preorderTraversal (TreeNode root) {
        //添加遍历结果的数组
        List<Integer> list = new ArrayList();
        //递归前序遍历
        preorder(list, root);
        //返回的结果
        int[] res = new int[list.size()];
        for(int i = 0; i < list.size(); i++)
            res[i] = list.get(i);
        return res;
    }
}

👉第二题:二叉树的中序遍历

题目描述

给定一个二叉树的根节点root,返回它的中序遍历结果。
数据范围:树上节点数满足 0 \le n \le 10000≤n≤1000,树上每个节点的值满足 -1000 \le val \le 1000−1000≤val≤1000
进阶:空间复杂度 O(n),时间复杂度 O(n)

示例

示例1

输入:{1,2,#,#,3}
返回值:[2,3,1]

在这里插入图片描述

示例2

输入:{}
返回值:[]

示例3

输入:{1,2}
返回值:[2,1]
在这里插入图片描述

示例4

输入:{1,#,2}
返回值:[1,2]
在这里插入图片描述

备注:
树中节点数目在范围 [0, 100] 内
树中的节点的值在[-100,100]以内

题解

import java.util.*;
public class Solution {
    public void inorder(List<Integer> list, TreeNode root){
        //遇到空节点则返回
        if(root == null)
            return;
        //先去左子树
        inorder(list, root.left);
        //再访问根节点
        list.add(root.val);
        //最后去右子树
        inorder(list, root.right);
    }
     
    public int[] inorderTraversal (TreeNode root) {
        //添加遍历结果的数组
        List<Integer> list = new ArrayList();
        //递归中序遍历
        inorder(list, root);
        //返回的结果
        int[] res = new int[list.size()];
        for(int i = 0; i < list.size(); i++)
            res[i] = list.get(i);
        return res;
    }
}

👉第三题:二叉树的后序遍历

题目描述

给定一个二叉树,返回他的后序遍历的序列。

后序遍历是值按照 左节点->右节点->根节点 的顺序的遍历。

数据范围:二叉树的节点数量满足 1 \le n \le 100 \1≤n≤100  ,二叉树节点的值满足 1 \le val \le 100 \1≤val≤100  ,树的各节点的值各不相同

样例图:

在这里插入图片描述

示例

示例1

输入:{1,#,2,3}
返回值:[3,2,1]
说明:如题面图

示例2

输入:{1}
返回值:[1]

题解

import java.util.*;
public class Solution {
    public void postorder(List<Integer> list, TreeNode root){
        //遇到空节点则返回
        if(root == null)
            return;
        //先去左子树
        postorder(list, root.left);
        //再去右子树
        postorder(list, root.right);
        //最后访问根节点
        list.add(root.val);
    }
     
    public int[] postorderTraversal (TreeNode root) {
        //添加遍历结果的数组
        List<Integer> list = new ArrayList();
        //递归后序遍历
        postorder(list, root);
        //返回的结果
        int[] res = new int[list.size()];
        for(int i = 0; i < list.size(); i++)
            res[i] = list.get(i);
        return res;
    }
}

👉第四题:求二叉树的层序遍历

描述
给定一个二叉树,返回该二叉树层序遍历的结果,(从左到右,一层一层地遍历)
例如:
给定的二叉树是{3,9,20,#,#,15,7},
在这里插入图片描述

该二叉树层序遍历的结果是
[
[3],
[9,20],
[15,7]
]

提示:
0 <= 二叉树的结点数 <= 1500

示例

示例1

输入:{1,2}
返回值:[[1],[2]]

示例2

输入:{1,2,3,4,#,#,5}
返回值:[[1],[2,3],[4,5]]

题解

/**
 * struct TreeNode {
 *    int val;
 *    struct TreeNode *left;
 *    struct TreeNode *right;
 * };
 */
 
class Solution {
public:
    /**
     *
     * @param root TreeNode类
     * @return int整型vector<vector<>>
     */
    //前序遍历模板;
    void f(TreeNode* root,int level,vector<vector<int>> &res){
        if(!root)return ;
        if(level>=res.size()){//最新的深度,申请一个数组存储;
            res.push_back(vector<int> {});
        }
        res[level].push_back(root->val);
        f(root->left,level+1,res);//遍历左子树;
        f(root->right,level+1,res);//遍历右子树;
    }
 
    vector<vector<int> > levelOrder(TreeNode* root) {
        // write code here
        vector<vector<int>> res;//存储最终结果;
        f(root,0,res);//前序遍历;
        return res;//返回结果;
    }
};

👉第五题:二叉树的最大深度

题目描述

求给定二叉树的最大深度,

深度是指树的根节点到任一叶子节点路径上节点的数量。

最大深度是所有叶子节点的深度的最大值。(注:叶子节点是指没有子节点的节点。)

数据范围:0 \le n \le 1000000≤n≤100000,树上每个节点的val满足 |val| \le 100∣val∣≤100

要求: 空间复杂度 O(1),时间复杂度 O(n)

示例1

输入:{1,2}
返回值:2

示例2

输入:{1,2,3,4,#,#,5}
返回值:3

题解

import java.util.*;
public class Solution {
    public int maxDepth (TreeNode root) {
        //空节点没有深度
        if(root == null)
            return 0;
        //返回子树深度+1
        return Math.max(maxDepth(root.left), maxDepth(root.right)) + 1;
    }
}

总结,刷题经验分享

📩Java基础学习主要以练习为主,很多朋友听完视频课程学会基础以后感觉对练手项目无从下手,这里推荐去牛客网看看,这里的IT题库内容很丰富,属于国内做的很好的IT学习网站,而且是课程+刷题+面经+求职+讨论区分享。

在这里插入图片描述
📩从基础开始练习,知识点编排详细,题目安排合理,题目表述以指导的形式进行。整个题单覆盖了java入门的全部知识点以及全部语法,通过知识点分类逐层递进,从基础开始到最后的实践任务,都会非常详细地指导你应该使用什么函数,应该怎么输入输出。
在这里插入图片描述
📩牛客网还提供题解专区和讨论区会有大神提供题解思路,对新手玩家及其友好,有不清楚的语法,不理解的地方,看看别人的思路,别人的代码,也许就能豁然开朗。

相关文章:

  • python专区--时间模块
  • 36、Java 中的 String、StringBuilder、StringBuffer、字符串常量池和 intern 方法
  • 基于正交设计的折射反向学习樽海鞘群算法
  • 国庆假期浏览了几十篇YOLO改进英文期刊,总结改进创新的一些相同点(期刊创新点持续更新)
  • 《计算机视觉基础知识蓝皮书》第5篇 目标检测基础
  • 提升能力和认知边界,最有效的方法是赚钱
  • Window下使用RegisterWindowMessage来实现消息通讯
  • Java 数组、排序和查找(1)
  • 你还没用过Mybatis-Plus?丝般顺滑,快速上手!
  • css3d动画:平移、旋转、缩放
  • 【英语:基础进阶_正式场景表达】F1.五步法搞定英文面试
  • SplitFS(SOSP‘19)
  • 【数据结构与算法】第十一篇:优先级队列
  • 【LeetCode】替换空格消失的数字分割链表除自身以外数组的乘积
  • 模糊控制之Sigmoidmf隶属度函数( PLC SCL代码)
  • CSS实用技巧干货
  • Linux各目录及每个目录的详细介绍
  • zookeeper系列(七)实战分布式命名服务
  • 从 Android Sample ApiDemos 中学习 android.animation API 的用法
  • 第十八天-企业应用架构模式-基本模式
  • 给初学者:JavaScript 中数组操作注意点
  • 基于axios的vue插件,让http请求更简单
  • 开发基于以太坊智能合约的DApp
  • 盘点那些不知名却常用的 Git 操作
  • 深入浅出Node.js
  • 为什么要用IPython/Jupyter?
  • Play Store发现SimBad恶意软件,1.5亿Android用户成受害者 ...
  • 积累各种好的链接
  • #我与Java虚拟机的故事#连载05:Java虚拟机的修炼之道
  • (4)logging(日志模块)
  • (附源码)spring boot公选课在线选课系统 毕业设计 142011
  • (附源码)ssm本科教学合格评估管理系统 毕业设计 180916
  • (十)c52学习之旅-定时器实验
  • (四)Controller接口控制器详解(三)
  • (转载)OpenStack Hacker养成指南
  • *上位机的定义
  • .Net 6.0 处理跨域的方式
  • .NET MVC第五章、模型绑定获取表单数据
  • .Net mvc总结
  • .NET/MSBuild 中的发布路径在哪里呢?如何在扩展编译的时候修改发布路径中的文件呢?
  • .net分布式压力测试工具(Beetle.DT)
  • .net流程开发平台的一些难点(1)
  • .Net面试题4
  • .NET命令行(CLI)常用命令
  • .NET命名规范和开发约定
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • @angular/cli项目构建--http(2)
  • [AI]文心一言爆火的同时,ChatGPT带来了这么多的开源项目你了解吗
  • [Angular] 笔记 6:ngStyle
  • [C#]winform制作仪表盘好用的表盘控件和使用方法
  • [hive] 窗口函数 ROW_NUMBER()
  • [iOS]中字体样式设置 API
  • [ios-必看] IOS调试技巧:当程序崩溃的时候怎么办 iphone IOS
  • [Java基础] Java中List.remove报错UnsupportedOperationException
  • [openGL]在ubuntu20.06上搭建openGL环境