算法笔记|Day34动态规划VII

news/2024/9/14 1:44:22/ 标签: 算法, 笔记, 动态规划

算法笔记|Day34动态规划VII

  • ☆☆☆☆☆leetcode 198.打家劫舍
    • 题目分析
    • 代码
  • ☆☆☆☆☆leetcode 213.打家劫舍II
    • 题目分析
    • 代码
  • ☆☆☆☆☆leetcode 337.打家劫舍 III
    • 题目分析
    • 代码

☆☆☆☆☆leetcode 198.打家劫舍

题目链接:leetcode 198.打家劫舍

题目分析

1.dp数组含义:dp[i]表示考虑下标i(包括i)以内的房屋,最多可以偷窃的金额。;
2.递推公式:dp[i]=Math.max(dp[i-2]+nums[i],dp[i-1])(如果偷第i个房间则为dp[i-2]+nums[i];如果不偷第i个房间则为dp[i-1],两者取最大值);
3.初始化:dp[0]=nums[0],dp[1]=Math.max(nums[0],nums[1])(dp[0]表示下标为0的房间最多偷窃的金额为nums[0],dp[1]表示从下标为0到1的房间最多偷窃的金额为Math.max(nums[0],nums[1]);
4.遍历顺序:从小到大。

代码

class Solution {public int rob(int[] nums) {if(nums.length==1)return nums[0];int dp[]=new int[nums.length];dp[0]=nums[0];dp[1]=Math.max(nums[0],nums[1]);for(int i=2;i<nums.length;i++)dp[i]=Math.max(dp[i-2]+nums[i],dp[i-1]);return dp[nums.length-1];}
}

☆☆☆☆☆leetcode 213.打家劫舍II

题目链接:leetcode 213.打家劫舍II

题目分析

对于一个数组,成环主要有三种情况:①考虑不包含首尾元素;②考虑包含首元素,不包含尾元素;③考虑包含尾元素,不包含首元素。事实上情况②或③均包括情况①,所以仅需考虑情况②和③中的最大值即可。
1.dp数组含义:dp[i]表示考虑下标i(包括i)以内的房屋,最多可以偷窃的金额。;
2.递推公式:dp[i]=Math.max(dp[i-2]+nums[i],dp[i-1])(如果偷第i个房间则为dp[i-2]+nums[i];如果不偷第i个房间则为dp[i-1],两者取最大值);
3.初始化:dp[0]=nums[0],dp[1]=Math.max(nums[0],nums[1])(dp[0]表示下标为0的房间最多偷窃的金额为nums[0],dp[1]表示从下标为0到1的房间最多偷窃的金额为Math.max(nums[0],nums[1]);
4.遍历顺序:从小到大。

代码

class Solution {public int rob(int[] nums) {if(nums.length==1)return nums[0];return Math.max(rob1(nums,0,nums.length-2),rob1(nums,1,nums.length-1));}public int rob1(int[] nums,int start,int end){if(start==end)return nums[start];int dp[]=new int[end-start+2];dp[start]=nums[start];dp[start+1]=Math.max(nums[start],nums[start+1]);for(int i=start+2;i<=end;i++)dp[i]=Math.max(dp[i-2]+nums[i],dp[i-1]);return dp[end];}
}

☆☆☆☆☆leetcode 337.打家劫舍 III

题目链接:leetcode 337.打家劫舍 III

题目分析

1.dp数组含义:dp[0]表示不偷该节点最多可以偷窃的金额,dp[1]表示偷该节点最多可以偷窃的金额;
2.递推公式:dp[0]=Math.max(left[0],left[1])+Math.max(right[0],right[1])(不偷该节点,要考虑左右子节点最多偷窃的金额总和,且左右子节点各自偷窃的金额最多为偷该节点与不偷该节点的最大值),dp[1]=root.val+left[0]+right[0](偷该节点,最多偷窃的金额总和为该节点金额与左右节点不偷最多偷窃的金额的和);
3.初始化:如果root=null,则返回{0,0}];
4.遍历顺序:后序遍历(左右中)。

代码

class Solution {public int rob(TreeNode root) {return Math.max(traversal(root)[0],traversal(root)[1]);}public int[] traversal(TreeNode root){int dp[]=new int[2];if(root==null)return dp;int left[]=traversal(root.left);int right[]=traversal(root.right);dp[0]=Math.max(left[0],left[1])+Math.max(right[0],right[1]);dp[1]=root.val+left[0]+right[0];return dp;  }
}

http://www.ppmy.cn/news/1516167.html

相关文章

系规学习第20天

1.过程要素管理&#xff08;几包试问 配变法案莲蓉&#xff09;&#xff1a; 对流程的执行、监控与调优是至关重要的&#xff0c;包括服务级别管理、服务报告管理、事件管理、问题管理、配置管理、变更管理、发布管理、安全管理&#xff0c;进行有效的支持并确保执行。 2. 服务…

异步编排利器:使用CompletableFuture优化服务页面响应速度

文章目录 1、什么是CompletableFuture异步编排&#xff1f;1.1、问题背景1.2、为什么使用CompletableFuture&#xff1f; 2、如何使用CompletableFuture进行异步编排&#xff1f;2.1、创建异步任务2.2、任务的串行执行2.3、多任务组合2.4、代码示例 3、总结 在如今的互联网应用…

Python基础—Python保护代码和数据的方法

保护代码和数据的安全性至关重要。无论是防止代码被轻易修改&#xff0c;还是确保数据的隐私与完整性&#xff0c;采取适当措施都是必不可少的。今天&#xff0c;我们就来揭开六大保护策略的神秘面纱&#xff0c;让初学者也能轻松掌握这些实用技巧。 1. 使用加密技术保护敏感…

每日掌握一个科研插图·2D密度图|24-08-21

小罗碎碎念 在统计学和数据可视化领域&#xff0c;探索两个定量变量之间的关系是一种常见的需求。为了更深入地理解这种关系&#xff0c;我们可以使用多种图形表示方法&#xff0c;这些方法在本质上是对传统图形的扩展和变体。 散点图&#xff1a;这是最基本的图形&#xff0c…

【Linux网络】CGI技术

欢迎来到 破晓的历程的 博客 ⛺️不负时光&#xff0c;不负己✈️ 文章目录 一、CGI技术概述二、CGI技术的工作原理三、CGI技术的特点四、CGI技术的局限性和发展趋势五、CGI技术的安全性措施 一、CGI技术概述 CGI&#xff08;Common Gateway Interface&#xff09;是一种用于…

专题---自底向上的计算机网络(数据链路层)

目录 计算机网络概述 物理层 数据链路层 网络层 传输层 应用层 网络安全 集线器与交换机的主要区别。 ‌工作原理与层次‌&#xff1a;集线器工作在OSI模型的物理层&#xff0c;可以看作是1层设备&#xff0c;而交换机主要工作在数据链路层&#xff0c;可以看作是2层设备…

系统编程-lvgl

带界面的MP3播放器 -- lvgl 目录 带界面的MP3播放器 -- lvgl 一、什么是lvgl&#xff1f; 二、简单使用lvgl 在工程中编写代码 实现带界面的mp3播放器 main.c events_init.c events_init.h 补充1&#xff1a;glob函数 补充2&#xff1a;atexit函数 一、什么是lvgl&a…

Spring Boot项目中集成Geth与以太坊区块链进行交互操作实例

前置条件已经安装Geth并启动。 现在我们讲一下Spring Boot项目中集成Geth&#xff0c;然后怎么以太坊区块链进行交互操作。 1、添加依赖到工程pom.xml <dependency> <groupId>org.web3j</groupId> <artifactId>core</artifactId> <versi…

SpringBoot集成kafka-生产者发送消息

springboot集成kafka发送消息 1、kafkaTemplate.send()方法1.1、springboot集成kafka发送消息Message对象消息1.2、springboot集成kafka发送ProducerRecord对象消息1.3、springboot集成kafka发送指定分区消息 2、kafkaTemplate.sendDefault()方法3、kafkaTemplate.send(...)和k…

微信小程序: including tag name selectors, ID selectors, and at

微信小程序报错&#xff1a; Some selectors are not allowed in component wxss, including tag name selectors, ID selectors, and attribute selectors. 1、组件和引用组件的页面不能使用 id 选择器&#xff08;#a&#xff09;、属性选择器&#xff08;[a]&#xff09;和标…

软件测试基础篇(2024版)

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 1、黑盒测试、白盒测试、灰盒测试 1.1 黑盒测试 黑盒测试又叫功能测试、数据驱动测试 或 基于需求规格说明书的功能测试。该类测试注重于测试软件的功能性需…

MySQL 数据库知识总结

一、数据库概述 定义与特点&#xff1a; MySQL 是一种开源的关系型数据库管理系统&#xff0c;以其高性能、可靠性和易用性而闻名。支持多用户、多线程操作&#xff0c;适用于各种规模的应用场景。提供丰富的数据类型和强大的查询语言&#xff08;SQL&#xff09;。 架构组成&a…

【极限性能,尽在掌控】ROG NUC:游戏与创作的微型巨擘

初见ROG NUC&#xff0c;你或许会为它的小巧体型惊讶。然而&#xff0c;这看似不起眼的机身内&#xff0c;蕴藏着游戏、创意的强大能量。 掌中风暴&#xff0c;性能无界 ROG NUC搭载英特尔高性能处理器&#xff0c;配合高速NVMe SSD固态硬盘以及可选的高端独立显卡&#xff08…

C++ wxWidgets图形界面开发用什么IDE最好?

在主流免费的IDE工具中&#xff0c;我们可以想到的支持cmake项目的工具就只有QtCreator&#xff0c;VisualStudio&#xff0c;VSCode这三个。其中QtCreator和VSCode支持WIndows&#xff0c;Mac&#xff0c;WIndows三大主流平台。但是VSCode在Ubuntu等系统下的支持并没有在WIndo…

windows mfc webview2 接收html信息

webview2导入到mfc参考&#xff1a; windows vs2022 MFC使用webview2嵌入网页-CSDN博客 webview2与js交互参考&#xff1a;WebView2教程(基于C)【四】JS与C互访&#xff08;上&#xff09;_window.chrome.webview.postmessage-CSDN博客 一、JS端发送和接收 JS中&#xff0c;…

速盾:cdn能防ip追踪吗?

CDN&#xff0c;即内容分发网络&#xff08;Content Delivery Network&#xff09;&#xff0c;是一种通过网络分布在多个地理位置的服务器集群来提供高效内容传输服务的技术。CDN的主要目的是通过就近提供内容来加快网站的加载速度&#xff0c;并减少因服务器过载而导致的延迟…

二叉树刷题(1)

二叉树题目讲解&#xff08;1&#xff09; 一、构建二叉树并且遍历&#xff08;1&#xff09;思路&#xff08;2&#xff09;代码 二、对称二叉树1、思路2、代码 三、相同的树1、思路2、代码 四、单值二叉树1、思路2、代码 五、另一棵树的子树1、思路2、代码 一、构建二叉树并且…

element table 翻页选中回显

使用element table 多选翻页时选中的数据没保留&#xff0c;查看文档以及资料发现得进行以下设置 1、在table上设置row-key&#xff0c;以及 selection-change“handleSelectionChange” 2、在type"selection"这一行上设置reserve-selection&#xff0c;我就是把这个…

翻译软件 Fastrans 开发日志 #01

目录 预览前言功能技术待办 预览 Github 仓库链接&#xff1a;https://github.com/YaoqxCN/Fastrans Gitee 仓库链接&#xff1a;https://gitee.com/yaoqx/Fastrans 求求给我点个 star 叭 qaq 现在才是 v1.0.0&#xff0c;给我个 star 鼓励我继续开发下去&#xff01; 我相信…

四、Docker使用

1. 快速入门 1.1. Docker背景介绍 Docker是一个开源的平台&#xff0c;用于开发、交付和运行应用程序。它能够在Windows&#xff0c;macOS&#xff0c;Linux计算机上运行&#xff0c;并将某一应用程序及其依赖项打包至一个容器中&#xff0c;这些容器可以在任何支持Docker的环…