【LeetCode每日一题】——337.打家劫舍 III

news2025/1/19 7:12:34

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【解题思路】
  • 七【题目提示】
  • 八【时间频度】
  • 九【代码实现】
  • 十【提交结果】

一【题目类别】

二【题目难度】

  • 中等

三【题目编号】

  • 337.打家劫舍 III

四【题目描述】

  • 小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为 root 。
  • 除了 root 之外,每栋房子有且只有一个“父“房子与之相连。一番侦察之后,聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”。 如果 两个直接相连的房子在同一天晚上被打劫 ,房屋将自动报警。
  • 给定二叉树的 root 。返回 在不触动警报的情况下 ,小偷能够盗取的最高金额 。

五【题目示例】

  • 示例 1:

    • 在这里插入图片描述
    • 输入: root = [3,2,3,null,3,null,1]
    • 输出: 7
      • 解释: 小偷一晚能够盗取的最高金额 3 + 3 + 1 = 7
  • 示例 2:

    • 在这里插入图片描述
    • 输入: root = [3,4,5,1,3,null,1]
    • 输出: 9
      • 解释: 小偷一晚能够盗取的最高金额 4 + 5 = 9

六【解题思路】

  • 利用动态规划的思想
  • 我们可以注意到,从根节点开始,要么选择根节点,要么不选择根节点,我们只需要这两种情况中收益最大的一种情况,其余的节点也是同理
  • 所以我们使用后序遍历整棵树,使用后序遍历的原因是,需要知道下面节点的收益情况
  • 如果选择当前节点,那么就加上不选择它的子节点的情况
  • 如果不选择当前节点,那么就将选择它的子节点的情况求和(此种情况又和上面其实是一样的,涉及到选还是不选的问题,自然而然就是一个递归)
  • 递归结束后返回一个数组,其中包括选根节点和不选根节点的收益情况,我们只需要选择最大的收益
  • 最后返回结果即可

七【题目提示】

  • 树 的 节 点 数 在 [ 1 , 1 0 4 ] 范 围 内 树的节点数在 [1, 10^4] 范围内 [1,104]
  • 0 < = N o d e . v a l < = 1 0 4 0 <= Node.val <= 10^4 0<=Node.val<=104

八【时间频度】

  • 时间复杂度: O ( n ) O(n) O(n),其中 n n n为树的节点个数
  • 空间复杂度: O ( n ) O(n) O(n),其中 n n n为树的节点个数

九【代码实现】

  1. Java语言版
class Solution {

    public int rob(TreeNode root) {
        int[] res = getResByDfs(root);
        return Math.max(res[0],res[1]);
    }

    public int[] getResByDfs(TreeNode root){
        if(root == null){
            return new int[]{0,0};
        }
        int[] left = getResByDfs(root.left);
        int[] right = getResByDfs(root.right);
        int selectVal = root.val + left[1] + right[1];
        int noSelectVal = Math.max(left[0],left[1]) + Math.max(right[0],right[1]);
        return new int[]{selectVal,noSelectVal};
    }
    
}
  1. C语言版
int* getResByDfs(struct TreeNode* root)
{
    if(root == NULL)
    {
        int* res = (int*)malloc(sizeof(int) * 2);
        res[0] = 0;
        res[1] = 0;
        return res; 
    }
    int* left = getResByDfs(root->left);
    int* right = getResByDfs(root->right);
    int selectVal = root->val + left[1] + right[1];
    int noSelectVal = fmax(left[0],left[1]) + fmax(right[0],right[1]);
    int* res = (int*)malloc(sizeof(int) * 2);
    res[0] = selectVal;
    res[1] = noSelectVal;
    return res; 
}

int rob(struct TreeNode* root)
{
    int* res = getResByDfs(root);
    return fmax(res[0],res[1]);
}

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

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

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

相关文章

数据指标体系的建设思考(三)

一、数据指标体系搭建流程 01、如何搭建数据指标体系 ▶ “德勤”的数据指标体系方法论 首先&#xff0c;我们先来学习一下优秀的数据指标体系搭建方法论。数据指标体系搭建方法论有不少优秀的方案&#xff0c;大部分都大同小异&#xff0c;在这里我们来聊一下“德勤”推荐的…

论文投稿指南——中国(中文EI)期刊推荐(第7期)

&#x1f384;&#x1f384; EI是国际知名三大检索系统之一&#xff0c;在学术界的知名度和认可度仅次于SCI&#xff01; 【前言】 想发论文怎么办&#xff1f;手把手教你论文如何投稿&#xff01;那么&#xff0c;首先要搞懂投稿目标——论文期刊。其中&#xff0c;中文期刊的…

Opencv(C++)笔记--形态学操作之开、闭操作、基本梯度计算、顶帽和黑帽操作

目录 1--开操作 2--闭操作 3--基本梯度计算 4--顶帽操作 5--黑帽操作 6--代码实例 1--开操作 ① 原理&#xff1a;先进行腐蚀操作&#xff0c;再进行膨胀操作&#xff1b; ② 作用&#xff1a;消除值高于邻近点的孤立点&#xff0c;达到去除图像中噪声的作用&#xff0…

Python零基础入门篇- Python的加密模块 - hashlib 与 base64

我们来学习一下 Python 中的加密模块&#xff0c;加密模块在工作中被广泛应用。比如数据的传入 不希望被捕获&#xff0c;通过把数据加密。这样即使被捕获也无法获取到数据的真实信息&#xff0c;今天我们就来学习一下关于加密的方法。 hashlib 模块 hashlib 模块的介绍 hashl…

SSH远程免密登录的两种方式

SSH远程免密登录的两种方式一、ssh远程登录操作1.先ping测试下看看网络是否通畅2.ssh 192.168.150.148二、ssh免密登录方式一1.生成公钥、私钥2.拷贝公钥到目标服务器3.测试ssh免密登录三、ssh免密登录方式二1.生成本机的公钥私钥2.打开本地公钥文件复制公钥信息3.将公钥存放到…

[虚幻引擎] UE4/5数字孪生 制作城市光束效果

一、模型导入 二、创建材质 创建材质曲线&#xff0c;为了能够更好的实现颜色的渐变过程&#xff0c;这里用了RGB三种颜色 三、创建蓝图BP_LightBeam 在构造函数中实现逻辑首先我们的思路是要制作数量不同的光束那么我们就要循环&#xff0c;循环的次数可根据你想要的数量来设…

BAT大厂都在用的Docker。学会这三招,面试、工作轻松hold住

上期我们以Jenkins为例&#xff0c;一边实战一边了解Docker的基础命令。这期&#xff0c;我们将带大家使用Docker搭建三个平时测试工作中非常有用的小工具。学会这三个实战之后&#xff0c;你就可以说对Docker不是浅尝即止在理论阶段&#xff0c;而是真正有一定了解&#xff0c…

Java学习笔记 --- MySQL-数据库

一、使用命令行窗口连接MySQL数据库 1、mysql -h 主机名 -P 端口 -u 用户名 -p密码 2、登录前&#xff0c;保证服务启动 示意图 二、数据库三层结构 1、所谓安装MySQL数据库&#xff0c;就是在主机安装一个数据库管理系统&#xff08;DBMS&#xff09;&#xff0c;这个管理程…

Metal每日分享,纯色图片滤镜效果

本案例的目的是理解如何用Metal实现纯色图片效果滤镜&#xff0c;主要就是生成纯色图片&#xff1b; Demo HarbethDemo地址 实操代码 // 纯色滤镜 ImageView.image C7Color.purple.mt.colorImage(with: CGSize(width: 600, height: 600))效果对比图 不同参数下效果 purpl…

[附源码]Python计算机毕业设计高校助学金管理系统Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

(19)深度点云学习--利用RGBD图三维重建room

1、主要参考 &#xff08;1&#xff09;最主要参考&#xff0c;官方的blog Make fragments — Open3D 0.16.0 documentation &#xff08;2&#xff09;操作流程参考 Python从RGBD数据进行3D场景重建 - 百度文库 &#xff08;3&#xff09;blog Open3d利用彩色图和深度图…

新冠第6天,简单总结下

大家好&#xff0c;我是彭涛&#xff01;今天是阳了个阳第6天&#xff0c;我已经完全康复了&#xff0c;没任何感觉了&#xff01;因为前几天发了篇文章&#xff0c;我去&#xff0c;阳了个阳&#xff0c;打了一把高端局&#xff01;很多人都知道我新冠阳性了&#xff0c;都来关…

如何做好疫情防控档案管理工作

近日&#xff0c;国内疫情虽整体可控&#xff0c;但各地区性突发疫情仍此起彼伏&#xff0c;防控攻坚战继续处于艰难的拉锯状态&#xff0c;那在疫情防控工作中的档案是如何收集、整理、形成的呢&#xff1f;什么是疫情防控档案&#xff1f;本文将带你走近疫情期间的档案&#…

cuda学习笔记1——cuda概述

cuda学习笔记1——cuda概述1. GPU架构特点2. CUDA线程模型3. CUDA内存模型4. CUDA编程模型第一个要掌握的编程要点&#xff1a;关键字第二个编程要点&#xff1a;数据传输参考&#xff1a; CUDA编程之快速入门 英伟达官方——CUDA C 编程指南 CUDA&#xff08;Compute Unified…

vue2和vue3的环境搭建

1. node 安装 可以使用nvm 对node 的版本进行控制 # 查看版本 $ npm -v 2.3.0#升级 npm cnpm install npm -g# 升级或安装 cnpm npm install cnpm -g2.vue2环境安装# 安装最新vue稳定版 $ cnpm install vue 二种方式创建vue2项目 vue create vuepro1 //vue的方式创建项目v…

Git的安装,理论基础与基本使用

前言 本文为Git的安装&#xff0c;理论基础与基本使用相关知识&#xff0c;下边将对Git的安装与环境配置&#xff0c;Git相关理论基础&#xff08;包含&#xff1a;Git 是什么&#xff0c;Git的三种状态&#xff0c;Git保证完整性&#xff09;&#xff0c;以及Git的相关操作&am…

form rules校验:动态table中input校验

问题描述 使用antd的form-model的rules表单校验 那如图表格中的input如何也一同校验&#xff1f; 如图可见规则是一个数据结构为二维数组的可动态生成的表格&#xff0c;如何对其中的input进行校验&#xff1f; 一维数组表格校验分析 先分析简单点的问题&#xff0c;表格是数…

Redis持久化RDB的三种触发机制及其优缺点

一、前言 大家都知道Redis是内存数据库&#xff0c;所有的数据都存放在内存中&#xff0c;如果没有配置持久化&#xff0c;当我们关闭redis服务器再重启后数据就全丢失了&#xff0c;于是需要开启redis的持久化功能&#xff0c;将数据保存到磁盘上&#xff0c;保证在redis重启…

全景也要更清晰,基于RK3588核心板的8K全景相机方案【飞凌嵌入式】

内容来源&#xff1a;飞凌嵌入式官网www.forlinx.com伴随着虚拟现实技术&#xff08;简称VR&#xff09;的热潮&#xff0c;VR全景影像开始兴起&#xff0c;全景相机市场也迎来了高速发展。近年来&#xff0c;360全景相机几乎成为了数码潮人和vlog拍摄者手中必不可少的一款产品…

Ghidra逆向工具之旅与二进制代码分析【3】

逆向工程中涉及到多种多样的工具(例如IDA Pro,Angr等),熟练使用这些工具可以化繁为简,使得程序分析工作得以顺利开展。本系列文章系统地介绍众多逆向工具中的一种——Ghidra,它是由美国国家安全局(NSA,National Security Agency)的研究理事会为 NSA 的网络安全任务开发…