Java日常练习题,每天进步一点点(57)

题目:求一个二叉树的右下角结点的值。

思路

先按照层次遍历的方式,遍历整棵树,将每一层最后一个结点的值保存下来,最后返回最后一层的最后一个结点的值即可。

代码实现

private int lastVal = 0;
public int findBottomLeftValue(TreeNode root) {
    // 用队列保存待遍历的结点
    Queue<TreeNode> queue = new LinkedList<>();
    queue.offer(root);
    while(!queue.isEmpty()) {
        int size = queue.size();
        lastVal = queue.peek().val;
        for(int i=0; i<size; i++) {
            TreeNode node = queue.poll();
            if(node.right != null) {
                queue.offer(node.right);
            }
            if(node.left != null) {
                queue.offer(node.left);
            }
        }
    }
    return lastVal;
}

示例说明

以如下的二叉树为例:

    1
   / \
  2   3
 /   / \
4   5   6

按照层次遍历的方式,遍历完整棵树的顺序为1->2->3->4->5->6。在遍历到最后一层时,由于每层的结点都是从左到右遍历的,所以在遍历到这一层时,最后一个结点一定是最右边的结点,即结点6。因此,最后输出的结果为6。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java日常练习题,每天进步一点点(57) - Python技术站

(0)
上一篇 2023年5月23日
下一篇 2023年5月23日

相关文章

  • Java 把json对象转成map键值对的方法

    将 JSON 对象转换成 Map 对象有两种方法: 1. 使用 Jackson 库 Jackson 是一个流行的 JSON 处理库,它可以轻松地将 JSON 转换成 Java 对象或 Map 对象,反之亦然。可以通过 Maven 或 Gradle 将 Jackson 依赖项添加到项目中: <dependency> <groupId>c…

    Java 2023年5月26日
    00
  • ArrayList源码和多线程安全问题分析

    ArrayList源码分析 介绍 ArrayList是Java中非常常用的一种数据结构,它提供了一种基于数组实现的动态数组的方式来存储和管理对象。 内部实现 ArrayList的内部实现是基于数组的,可以使用数组索引来访问其中的元素,底层使用了Object[]数组来存储元素。当添加一个元素时,ArrayList会将其添加到数组的末尾,如果数组已满,Array…

    Java 2023年5月26日
    00
  • struts2中实现多个文件同时上传代码

    当在Struts2中需要同时上传多个文件时,需要进行以下几个步骤: 1.在JSP中设置表单属性 enctype=multipart/form-data,以便能够上传文件。 <form action="upload.action" method="post" enctype="multipart/form…

    Java 2023年5月20日
    00
  • Java中注解的工作原理

    下面是Java中注解的工作原理的完整攻略。 什么是Java注解 Java注解是一种元数据机制,其本质是为了给Java程序提供更好的描述、配置和使用方式的一种注解技术。注解可以被限定用于某些类型、方法、字段或方法参数等Java程序中的特定部分,通过注解可以传递一定的元数据信息,例如对应的某个方法的功能、某个属性的值或某个参数的约束等等。 注解在Java程序中的…

    Java 2023年5月20日
    00
  • Jackson序列化丢失泛型的解决

    在Java中,使用Jackson库进行序列化和反序列化是非常常见的。然而,当我们使用泛型时,Jackson序列化可能会丢失泛型信息,导致反序列化时出现问题。在本文中,我们将详细讲解如何解决Jackson序列化丢失泛型的问题,并提供两个示例来说明如何使用这些方法。 问题描述 当我们使用泛型时,Jackson序列化可能会丢失泛型信息。例如,考虑以下示例: pub…

    Java 2023年5月18日
    00
  • 解决maven update project 后项目jdk变成1.5的问题

    以下是详细的攻略: 背景 在使用 Maven 更新项目后,有时会发现项目的 JDK 版本被更改为了1.5(或其他版本),造成编译失败等问题。这种情况通常是因为 Maven 没有正确识别项目的 JDK 版本而导致的。 解决方法 方案一:手动配置 Maven 设置 找到你的 Maven 安装目录下的 conf 目录,进入其中的 settings.xml 文件。 …

    Java 2023年5月19日
    00
  • Java常用字符串工具类 字符串智能截取(3)

    Java常用字符串工具类 字符串智能截取(3) 引言 在Java开发中,字符串操作是我们最为常见的操作之一。字符串截取是字符串操作的重要之一。常规的字符串截取是通过String类的substring()方法来实现的。然而,当我们需要截取的字符串位置不确定时,怎么办?本篇文章将为大家介绍如何使用Java字符串智能截取工具类,满足大家的需求。 字符串智能截取 字…

    Java 2023年5月26日
    00
  • selenium UI自动化实战过程记录

    Selenium UI自动化实战过程记录 安装Selenium Selenium是一个自动化测试框架,可以模拟用户在浏览器中的操作,比如点击、输入等。为了使用Selenium,需要先安装Selenium WebDriver。 可以使用pip安装Selenium: pip install selenium 环境配置 要使用Selenium,需要一个浏览器和对应…

    Java 2023年6月15日
    00
合作推广
合作推广
分享本页
返回顶部