力扣题解654:最大二叉树

article/2025/7/4 4:51:39

一、题目内容

题目要求根据一个不重复的整数数组 nums 构建最大二叉树。最大二叉树的构建规则如下:

  1. 创建一个根节点,其值为 nums 中的最大值。
  2. 递归地在最大值左边的子数组前缀上构建左子树。
  3. 递归地在最大值右边的子数组后缀上构建右子树。
  4. 返回由 nums 构建的最大二叉树。

二、题目分析

输入和输出
  • 输入:一个不重复的整数数组 nums
  • 输出:构建好的最大二叉树的根节点(TreeNode 类型)。
递归函数 constructMaximumBinaryTree 的逻辑
  1. 基本情况:如果 nums 的大小为 1,直接返回以该唯一元素为值的节点。
  2. 找到最大值:遍历 nums 找到最大值及其索引。
  3. 创建根节点:以最大值创建根节点。
  4. 递归构建左子树:如果最大值左边有元素,递归构建左子树。
  5. 递归构建右子树:如果最大值右边有元素,递归构建右子树。
  6. 返回根节点:返回构建好的根节点。

三、代码解答

1.C++ 代码

class Solution {
public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {// 处理空数组的情况if (nums.empty()) return nullptr;// 基本情况:如果数组只有一个元素,直接返回该节点if (nums.size() == 1) return new TreeNode(nums[0]);// 初始化最大值和索引int maxvalue = nums[0];int index = 0;// 遍历数组找到最大值及其索引for (int i = 1; i < nums.size(); i++) {if (nums[i] > maxvalue) {maxvalue = nums[i];index = i;}}// 创建根节点TreeNode* node = new TreeNode(maxvalue);// 递归构建左子树:如果左边有元素if (index > 0) {// 提取左子数组:从开始到最大值索引之前的部分vector<int> vecleft(nums.begin(), nums.begin() + index);// 递归调用构建左子树node->left = constructMaximumBinaryTree(vecleft);}// 递归构建右子树:如果右边有元素if (index < nums.size() - 1) {// 提取右子数组:从最大值索引之后到结束的部分vector<int> vecright(nums.begin() + index + 1, nums.end());// 递归调用构建右子树node->right = constructMaximumBinaryTree(vecright);}// 返回根节点return node;}
};


2.详细注释

1.成员变量

  • TreeNode* constructMaximumBinaryTree(vector<int>& nums):主函数,用于递归构建最大二叉树并返回根节点。

2.递归函数 constructMaximumBinaryTree

  1. 空数组检查:如果 nums 为空,返回 nullptr
  2. 基本情况:如果 nums 只有一个元素,直接返回以该元素为值的节点。
  3. 找到最大值:遍历 nums 找到最大值及其索引。
  4. 创建根节点:以最大值创建根节点 node
  5. 递归构建左子树:如果最大值左边有元素,提取左子数组并递归构建左子树。
  6. 递归构建右子树:如果最大值右边有元素,提取右子数组并递归构建右子树。
  7. 返回根节点:返回构建好的根节点 node

3.回溯和递归的详细解释

1.递归

递归是一种函数调用自身的方法,用于解决复杂问题。在本题中,递归用于逐步构建最大二叉树的每个子树。

  • 递归调用:每次递归调用时,我们通过找到当前子数组的最大值确定当前子树的根节点,然后递归处理左子数组和右子数组。
  • 终止条件:递归的终止条件是子数组为空或只有一个元素。
2.回溯

回溯是一种在递归调用返回后恢复状态的机制。在本题中,每次递归调用返回后,我们通过更新子数组的范围,恢复到当前子树的状态。这样可以确保每次递归返回后,状态正确,不会影响后续的递归调用。

4.示例

假设输入数组 nums = [3, 2, 1, 6, 0, 5]

  1. 第一次调用
    • 最大值是 6,索引是 3。
    • 创建根节点 6。
    • 左子数组是 [3, 2, 1],右子数组是 [0, 5]
    • 递归构建左子树和右子树。
  2. 左子树构建
    • 子数组 [3, 2, 1]
      • 最大值是 3,索引是 0。
      • 创建节点 3。
      • 左子数组为空,右子数组是 [2, 1]
      • 递归构建右子树。
  3. 右子树构建
    • 子数组 [0, 5]
      • 最大值是 5,索引是 1。
      • 创建节点 5。
      • 左子数组是 [0],右子数组为空。
      • 递归构建左子树。
  4. 构建的最大二叉树为:

      6
     / \
    3   5
     \  /
      2 0
       \
        1


http://www.hkcw.cn/article/VXfPbwRkrJ.shtml

相关文章

车载诊断架构 --- DTC消抖参数(Trip Counter DTCConfirmLimit )

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 做到欲望极简,了解自己的真实欲望,不受外在潮流的影响,不盲从,不跟风。把自己的精力全部用在自己。一是去掉多余,凡事找规律,基础是诚信;二是…

75.解决当编辑完用户消息,确认重新生成AI回答时,已有的AI回答还是存在,并且新生成的回答并没有显示到气泡里bug

在上一个bug解决完后&#xff0c;又出来一个bug&#xff0c;我真是服了哈哈哈 新的bug是&#xff1a; 当编辑完用户消息&#xff0c;确认重新生成AI回答时&#xff0c;已有的AI回答还是存在&#xff0c;并且新生成的回答并没有显示到气泡里 出现这个bug的原因还是出现在rege…

C# 用户控件(User Control)详解:创建、使用与最佳实践

在C#应用程序开发中&#xff0c;用户控件&#xff08;User Control&#xff09;是一种强大的工具&#xff0c;它允许开发者将多个标准控件组合成一个可复用的自定义组件。无论是Windows Forms还是WPF&#xff0c;用户控件都能显著提高UI开发的效率&#xff0c;减少重复代码&…

SpringBoot-配置Spring MVC

一、Spring MVC回顾 Spring MVC是一种常用的Java Web框架&#xff0c;它提供了一种基于MVC模式的开发方式&#xff0c;可以方便地实现Web应用程序。在Spring MVC中&#xff0c;WebMvcConfigurer是一种常用的配置方式&#xff0c;可以允许我们自定义Spring MVC的行为&#xff0c…

Python训练营打卡 Day26

知识点回顾&#xff1a; 函数的定义变量作用域&#xff1a;局部变量和全局变量函数的参数类型&#xff1a;位置参数、默认参数、不定参数传递参数的手段&#xff1a;关键词参数传递参数的顺序&#xff1a;同时出现三种参数类型时 ——————————————————————…

【Delphi】接收windows文件夹中文件拖拽

本文根据EmailX45的视频文件&#xff0c;进行了优化改进&#xff0c;原文参见&#xff1a;Delphi: Drag and Drop Files from Explorer into TPanel / TMemo - YouTube 在Windows中&#xff0c;如果将选择的文件拖动到Delphi程序的控件上&#xff0c;有很多实现方法&#xff0c…

电脑的ip地址会自动变怎么办?原因解析和解决方法

在当今互联网时代&#xff0c;IP地址是每台联网设备的"身份证"&#xff0c;但很多用户都遇到过IP地址自动变化的情况。这种现象既可能发生在内网&#xff08;局域网&#xff09;环境中&#xff0c;也可能出现在外网&#xff08;公网&#xff09;连接中。要理解IP地址…

CppCon 2014 学习: C++11 in the Wild

介绍了三个现代 C 的实用工具或功能。下面是对每部分的解释和总结&#xff1a; 1. Auto() 宏 用途&#xff1a;在作用域结束时自动执行清理代码&#xff0c;类似于 RAII 的机制。功能&#xff1a;你可以定义一段代码&#xff0c;在作用域结束时自动执行&#xff08;不需要手动…

三大模块曝光:分钟级搭建专属平台,解锁算力灵活操控新体验,重新定义智能开发效率天花板

一. 蓝耘元生代 MaaS介绍及简单使用 背景介绍 创新产品定位&#xff1a; 蓝耘元生代 MaaS 平台于 2024 年 11 月 28 日推出&#xff0c;非传统智算平台&#xff0c;以资源聚合能力整合上下游资源&#xff0c;为用户提供优质全面服务。 核心模块功能&#xff1a; 集成智算算…

乾坤qiankun的使用

vue2 为主应用 react 为子应用 在项目中安装乾坤 yarn add qiankun # 或者 npm i qiankun -Svue主应用 在main.js中新增 &#xff08;需要注意的是路由模型为history模式&#xff09; registerMicroApps([{name: reactApp,entry: //localhost:3011,container: #container,/…

FreeRTOS实时操作系统学习笔记

一 RTOS入门 1.1 裸机与RTOS介绍&#xff08;了解&#xff09; 裸机编程是指在嵌入式系统中&#xff0c;直接在硬件上运行代码&#xff0c;没有操作系统的支持。这种方式下&#xff0c;开发者需要完全掌握硬件资源&#xff0c;包括时钟、中断、外设等。任务调度和资源管理都由…

MCP还是A2A?AI未来技术选型深度对比分析报告

引言 MCP&#xff08;Multi-Core Processor&#xff09;与A2A&#xff08;Asynchronous to Asynchronous&#xff09;分别代表了计算架构发展中的两种重要范式。前者延续传统冯诺依曼体系的并行优化路径&#xff0c;后者则试图突破同步时钟的物理限制。理解二者的本质差异&…

逐步检索增强推理的跨知识库路由学习

摘要 多模态检索增强生成&#xff08;MRAG&#xff09;在多模态大语言模型&#xff08;MLLM&#xff09;中通过在生成过程中结合外部知识来减轻幻觉的发生&#xff0c;已经显示出了良好的前景。现有的MRAG方法通常采用静态检索流水线&#xff0c;该流水线从多个知识库&#xff…

OpenRouter使用指南

OpenRouter 是一个专注于大模型&#xff08;LLM&#xff09;API 聚合和路由的服务平台&#xff0c;旨在帮助开发者便捷地访问多种主流大语言模型&#xff08;如 GPT-4、Claude、Llama 等&#xff09;&#xff0c;并提供统一的接口、成本优化和智能路由功能。以下是它的核心功能…

【Linux】权限chmod命令+Linux终端常用快捷键

目录 linux中权限表示形式 解析标识符 权限的数字序号 添加权限命令chmod 使用数字表示法设置权限 使用符号表示法设置权限 linux终端常用快捷键 &#x1f525;个人主页 &#x1f525; &#x1f608;所属专栏&#x1f608; 在 Linux 系统里&#xff0c;权限管理是保障系…

2018ToG | 可逆的灰度图像

写在前面&#xff1a;这篇论文是比较早期的论文了&#xff0c;但由于本人是第一次见到该方向的相关研究&#xff0c;所以觉得比较新奇。本文用以梳理这篇论文的阅读思路&#xff0c;文末附上了一些个人思考。 0. Abstract 一旦彩色图像被转换为灰度图像&#xff0c;普遍认为即…

Python打卡训练营Day43

DAY 43 复习日 作业&#xff1a; kaggle找到一个图像数据集&#xff0c;用cnn网络进行训练并且用grad-cam做可视化 数据集地址&#xff1a;Lung Nodule Malignancy 肺结核良恶性判断 进阶&#xff1a;并拆分成多个文件 import os import pandas as pd import numpy as np from…

mem0ai/mem0 v0.1.102版本全面升级,解锁多项前沿功能与文档优化!

大家好&#xff01;今天我们为大家带来mem0ai/mem0项目的重大版本更新——v0.1.102&#xff01;本次更新不仅带来了全新的功能扩展&#xff0c;更对项目的文档体系进行了深度优化&#xff0c;提升了整体用户体验和集成便捷性。无论你是mem0ai/mem0的忠实用户&#xff0c;还是刚…

导入典籍数据

1.从网上获取中医相关典籍数据&#xff0c;数目共600txt&#xff0c;总篇数14万 2.数据处理 获取到的数据结构大致如下 一个txt表示一本书&#xff0c;开头存有书籍相关的名字&#xff0c;作者&#xff0c;朝代&#xff0c;年份&#xff0c;之后每一个<目录>下都跟有一…

状态机实现文件单词统计

系统如何查找可执行文件 默认&#xff1a;在PATH路径下寻找文件文件下 执行当前目录下文件&#xff1a; ./&#xff1a;指定文件目录是当前目录 ./count:执行当前目录文件 编译.c文件为运行文件 gcc -o count 0voice.c #将0voice.c编译为名字count 为什么主函数要那么写&a…