代码随想录Day16 LeetCode T654 最大二叉树 T617 合并二叉树 T700 二叉搜索树中的搜索

news2025/1/16 15:48:39

  本文思路和更详细的解析来自于:代码随想录 (programmercarl.com)​​​​​​

LeetCode T654 最大二叉树

题目链接:654. 最大二叉树 - 力扣(LeetCode)

 

题目思路:

这题和昨天的题目很像,我们仍然需要构造一棵二叉树,我们仍然使用递归来完成,以下我们开始进行递归三部曲,我们需要知道,构建一棵树最好使用前序遍历

1.递归函数的设计,参数和返回值

这里返回值是TreeNode(树的一个节点),传入参数的我们需要操作的数组nums,和左右区间,注意,我们每一题要规定好左右区间的使用,不要一会儿使用闭区间,一会儿使用左闭右开区间.

public TreeNode constructMaximumBinaryTree1(int[] nums, int left, int right)

2.终止条件:

这里我们如果遇到空数组,我们需要返回,如果遇到单个节点,我们也可以直接返回

        if(right-left<1)
        {
            return null;
        }
        if(right- left == 1)
        {
            return new TreeNode(nums[left]);
        }

3.单次递归的实现

        int index = left;//最大值的下标
        int maxVal= nums[index];//最大值
        for(int i = left+1;i<right;i++)
        {
            if(nums[i]>maxVal)
            {
                maxVal = nums[i];
                index = i;
            }
        }
        TreeNode node = new TreeNode(maxVal);
        node.left = constructMaximumBinaryTree1(nums,left,index);//左
        node.right = constructMaximumBinaryTree1(nums,index+1,right);//右
        return node;

这里注意,我们这样使用左右区间来定位是为了节省空间和创建新数组的书写方法,我们也可以使用每次创建左右数组的方式来区分左右区间.

题目代码:

class Solution {
    public TreeNode constructMaximumBinaryTree(int[] nums) {
        return constructMaximumBinaryTree1(nums,0,nums.length);
        

    }
    public TreeNode constructMaximumBinaryTree1(int[] nums,int left,int right)
    {
        
        
        TreeNode node;
        //没有元素
        if(right - left < 1)
        {
            return null;
        }
        //一个元素
        if(right - left == 1)
        {
            return new TreeNode(nums[left]);
        }
        else
        {
            int index  = left;
            int maxVal = nums[index];
            for(int i = left+1;i<right;i++)
            {
                if(nums[i]>maxVal)
                {
                    maxVal = nums[i];
                    index = i;
                }
            }
            node = new TreeNode(nums[index]);
            node.left = constructMaximumBinaryTree1(nums,left,index);
            node.right = constructMaximumBinaryTree1(nums,index+1,right);
        }
        return node;

    }
   
}

LeetCode T617 合并二叉树

题目链接:617. 合并二叉树 - 力扣(LeetCode)

题目思路:

同时操作两棵二叉树,这里我们仍然使用递归去操作,使用前序遍历,这样比较符合直觉,当然中序和后序遍历也是可以的,这里我们使用前序来操作,我们仍然遵循递归三部曲

1.确定函数返回值和参数

我们这里希望每次返回的是TreeNode类型的数值,所以返回值是TreeNode,操作参数为两棵树

public TreeNode mergeTrees(TreeNode root1, TreeNode root2)

2.终止条件

这里我们是两棵树,首先如果第一棵树为空,我们直接返回第二棵树即可,第二棵树同理也是这样操作,有人可能觉得两棵树都为空的条件没有讨论,这里我们可以认为两棵树都为空的情况已经包含在内了,因为假设两棵树都为空,我返回任何一棵树实际上就都表示的是空节点了

        if(root1 == null)
        {
            return root2;
        }
        if(root2 == null)
        {
            return root1;
        }

3.一次递归

这里我们再root1的基础上修改,就不用创建新的树进行操作了,节省空间和时间

        root1.val +=root2.val;
        root1.left = mergeTrees(root1.left,root2.left);
        root1.right = mergeTrees(root1.right,root2.right);
        return root1;

题目代码:

class Solution {
    public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {
        if(root1 == null)
        {
            return root2;
        }
        if(root2 == null)
        {
            return root1;
        }
        root1.val +=root2.val;
        root1.left = mergeTrees(root1.left,root2.left);
        root1.right = mergeTrees(root1.right,root2.right);
        return root1;

    }
}

LeetCode T700 二叉搜索树中的搜索

题目链接:700. 二叉搜索树中的搜索 - 力扣(LeetCode)

题目思路:

这题我们只要根据二叉搜索树的左子树的值比根节点小,右子树的值比根节点大这个特性来解决问题就行,分递归法和迭代法解决问题

1.递归

1.1 函数参数和返回值

使用题目的原本的参数和返回值即可

1.2终止条件

只要树的节点为空或者只有一个节点而且恰好就等于我们要寻找的数值,直接发返回

        if(root == null || root.val == val)
        {
            return root;
        }
1.3 递归过程

如果目前遍历的节点比我要寻找的数要大,就在右子树找,否则在左子树寻找

        if(val<root.val)
        {
            return searchBST(root.left,val);
        }
        if(val>root.val)
        {
            return searchBST(root.right,val);
        }
        return null;

2.迭代法

思路和上面类似,不做赘述

class Solution {
    // 迭代,利用二叉搜索树特点,优化,可以不需要栈
    public TreeNode searchBST(TreeNode root, int val) {
        while (root != null)
            if (val < root.val) root = root.left;
            else if (val > root.val) root = root.right;
            else return root;
        return null;
    }
}

题目代码:见上文

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1081315.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue原生实现element上传多张图片浏览删除

vue原生实现element上传多张图片浏览删除 <div class"updata-component" style"width:100%;"><div class"demo-upload-box clearfix"><div class"demo-upload-image-box" v-if"imageUrlArr && imageUrlAr…

使用 Eziriz .NET Reactor 对c#程序加密

我目前测试过好几个c#加密软件。效果很多时候是加密后程序执行错误&#xff0c;或者字段找不到的现象 遇到这个加密软件用了一段时间都很正常&#xff0c;分享一下使用流程 破解版本自行百度。有钱的支持正版&#xff0c;我用的是 Eziriz .NET Reactor 6.8.0 第一步 安装 Ezi…

内存操作函数(memcpy、memmove、memset、memcmp)---- C语言

文章目录 摘要1. memcpy1.1 函数介绍1.2 模拟实现 2. memmove2.1 函数介绍2.2 模拟实现 3. memset3.1 函数介绍 4. memcmp4.1 函数介绍 摘要 本篇文章介绍了C语言中常用的内存操作函数&#xff0c;包括 memcpy、memmove、memset和memcpy。这些函数用于处理内存数据的复制、移动…

新鲜速递:Spring Cloud Alibaba环境在Spring Boot 3时代的快速搭建

了解 首先&#xff0c;Spring Cloud Alibaba使用的是Nacos作为服务注册和服务发现的中间件。 能力在提供者那里&#xff0c;而消费者只需知道提供者提供哪些服务&#xff0c;而无需关心提供者在哪里&#xff0c;实际调用过程如下图 准备工作 1、需要下载并安装Nacos最新版…

计算机丢失msvcr120.dll解决办法,快速解决的力量文件丢失

关于计算机丢失msvcr120.dll应该很多朋友都遇到过&#xff0c;本篇文章将和大家探讨一下关于计算机丢失msvcr120.dll解决办法。同时想和大叫一起了解一下msvcr120.dll文件到底有什么作用&#xff0c;是不是必须将其恢复。 一.msvcr120.dll的作用 msvcr120.dll文件时电脑中的一…

从 0 到 1 ,手把手教你编写《消息队列》项目(Java实现) —— 编写服务器

文章目录 一、自定义应用层协议请求与响应channel 二、自定义请求格式三、自定义响应格式四、服务器代码编写 一、自定义应用层协议 咱们这里的客户端与服务器的通信是基于TCP协议实现的. 当前要交互的 Message,以及调用各种API的请求,其实都是二进制数据. 因此咱们要自定义…

使用香橙派并基于Linux实现最终版智能垃圾桶项目 --- 上

硬件接线 & 最终实现图 目录 项目需求 需求1&#xff0c;2&#xff0c;3 --- 蜂鸣器&#xff0c;舵机&#xff0c;测距传感器的配合使用 实现思路&#xff1a; 代码展示&#xff1a; v1.c&#xff1a; 需求4 --- socket服务器实现远程通讯控制的实现 代码展示&#…

电子科大软件系统架构设计——系统架构设计

文章目录 系统架构设计系统设计概述系统设计定义系统设计过程系统设计活动系统设计基本方法系统设计原则系统设计方法分类面向对象系统分析与设计建模过程 系统架构基础系统架构定义系统架构设计定义系统架构作用系统架构类型系统总体架构系统拓扑架构系统拓扑架构类型系统拓扑…

网络原理~初识

今天开始介绍的是网络&#xff0c;这是最核心最重要的板块之一~ 目录 网络互连 局域网 LAN 广域网WAN 网络通信基础 IP地址 端口号 协议 发送方的工作 应用层 传输层 网络层 数据链路层 物理层 接收方的工作 网络互连 随着时代的发展&#xff0c;越来越需要计算…

C语言-贪吃蛇 1.输入控制ncurse

一、为什么要用nurse C语言中的gets()、scanf()、getchar()等函数是在用户输入后需要按下Enter键才能执行代码&#xff0c;而贪吃蛇要求按下按键后立即对蛇的方向进行操作&#xff0c;所以根据贪吃蛇功能的需求引入ncurse&#xff0c;让用户输入后就能让蛇进行对应的行动。 二、…

C#和JS交互之Microsoft.ClearScript.V8(V8引擎)

之前测试了很多JS引擎&#xff0c;都只支持es5语法&#xff0c;不支持执行es6&#xff0c;测试了下微软的V8反正能跑通&#xff0c;应该是支持的。还得是微软呀。 如图&#xff1a;安装相关包&#xff1a; 这是参考的官方V8代码 using Microsoft.ClearScript.JavaScript; us…

STM32使用HAL库驱动DS3231

1、STM32通讯口配置 启动IIC&#xff0c;默认配置即可。 2、头文件 #ifndef __DS3231_H #define __DS3231_H#include "main.h"#define DS3231_COM_PORT hi2c1 /*通讯端口*//**************************** defines *******************************/ #define DS3231…

什么是UI自动化测试工具?

UI自动化测试工具有着AI技术驱动&#xff0c;零代码开启自动化测试&#xff0c;集设备管理与自动化能力于一身的组织级自动化测试管理平台。基于计算机视觉技术&#xff0c;可跨平台、跨载体执行脚本&#xff0c;脚本开发和维护效率提升至少50%;多端融合统一用户使用体验&#…

淘宝天猫店铺所有商品数据接口,淘宝API接口

获取淘宝店铺所有商品数据接口的步骤如下&#xff1a; 获取授权&#xff1a;使用 OAuth 2.0 协议对应用进行授权&#xff0c;以便能够访问店铺的商品信息。获取店铺信息&#xff1a;使用淘宝 API 的 taobao.shop.get 接口&#xff0c;传入店铺的 user_id 参数&#xff0c;获取…

Ghidra101再入门(上?)-Ghidra架构介绍

Ghidra101再入门(上&#xff1f;)-Ghidra架构介绍 最近有群友问我&#xff0c;说&#xff1a;“用了很多年的IDA&#xff0c;最近想看看Ghidra&#xff0c;这应该怎么进行入门&#xff1f;“这可难到我了。。 我发现&#xff0c;市面上虽然介绍Ghidra怎么用的文章和书籍很多&…

ASEMI整流桥GBU810参数,GBU810封装

编辑-Z GBU810参数描述&#xff1a; 型号&#xff1a;GBU810 最大直流反向电压VR&#xff1a;1000V 最大工作峰值反向电压VRWM&#xff1a;700V 最大平均正向电流IF&#xff1a;8A 非重复正向浪涌电流IFSM&#xff1a;200A 操作和储存温度范围TJ ,TSTG&#xff1a;-55 t…

Ubuntu18.04下载安装基于使用QT的pcl1.13+vtk8.2,以及卸载

一、QVTKWidget、QVTKWidget2、QVTKOpenGLWidget、QVTKOpenGLNativeWidget 区别 1.Qt版本 Qt5.4以前版本&#xff1a;QVTKWidget2/QVTKWidget。 Qt5.4以后版本&#xff1a;QVTKOpenGLWidget/QVTKOpenGLWidget。 2.VTK版本(Qt版本为5.4之后) 在VTK8.2以前的版本&#xff1a;QVT…

企业如何使用CRM客户管理系统全面了解客户

B2B业务由于决策链长&#xff0c;涉及的部门和人员多&#xff0c;购买周期短则2、3个月&#xff0c;长则一年半载的原因一直被大家痛呼难做。B2B业务要求企业去认识客户&#xff0c;更要深入地了解客户。基于这种需求&#xff0c;使用CRM客户管理系统是企业全面了解客户的重要手…

C++入门之命名空间详解

一、为什么要使用命名空间 命名空间的功能就是区分不同的代码段&#xff0c;避免使用不同代码时带来变量名冲突的问题。 在写C语言代码时&#xff0c;常常回面临命名冲突的问题。例如&#xff1a; 可以成功运行。 但是如果要使用 time.h 头文件时&#xff0c;就会与库发生冲突…

C++primer 第二章 变量和基本类型

昨天思考了一下&#xff0c;感觉明白了。于是报名了软考&#xff0c;还有挑战z杯&#xff0c;想着四级还要不要报&#xff0c;毕竟我也不是有天赋的人&#xff0c;就只能努力去做个努力的人。加油!!! 不知道未来怎么样&#xff0c;那就走好现在吧&#xff01;&#xff01;&…