动态规划入门,从简单递归到记忆化搜索到动态规划

动态规划入门,从简单递归到记忆化搜索到动态规划

打家劫舍

在这里插入图片描述

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

思路:

首先看到题目可以转换到当前这个位置选择或者不选的场景,比如说,首先我们选择了第一个,那么下一次能选择的第一个是第三个,如果不选第一个的话,下一个能选择的就是第二个.

注意点

  1. 对于结束的地方,刚开始大家可能会想着这个时候会是结束的地方,需要返回中的sum结果,但是我们需要知道这个地方返回的是当前位置能有的收益是多少,如果当前这个位置已经 < 0,那么这时候结果就是0。
  2. int res = Math.max(dfs(i - 1), dfs(i - 2) + nums[i]); 这代表我们在当前i的这个位置能有的两种情况,对于第一种情况,表示在当前这个位置我们不进行选择,可以在下一个位置进行选择。第二种情况表示我们选择了当前这个位置,体现在将当前的收益进行相加,下一次能选择的第一个位置就是dfs(i - 2),最后选择这两种情况的最大值。
  3. 返回res的结果。

上述情况会超时,我们分析一下是哪些时候会重复计算:

在这里插入图片描述
上述情况中,可以看到2的这种情况会重复计算,我们可以在计算得到2的结果之后,将2的结果保存到map中或者数组中,这样下次需要2的结果的时候直接从map中进行查找就可以,这时候O(1)的时间就可以获得。

记忆化搜索

class Solution {private int nums[];HashMap<Integer,Integer> hashmap = new HashMap<>(); // 记忆化数组public int rob(int[] nums) {this.nums = nums;return dfs(nums.length - 1);}public int dfs(int i){if (i < 0){return 0;}if (hashmap.containsKey(i)){ // 如果当前这个位置之前已经算过,直接去记忆化数组中拿return hashmap.get(i);}int res = Math.max(dfs(i - 1), dfs(i - 2) + nums[i]);hashmap.put(i,res); // 每次计算一个结果 就将当前的结果存入到记忆化数组中return res;}
}

和上面的代码优化的地方就是加入了一个记忆化数组,如果一个位置的结果计算过,就将结果存入到记忆化数组中,之后需要这个结果的时候,就从记忆化数组中进行获取。

从记忆化搜索到动态规划

我们使用图示的方法:

步骤

1、首先查看dfs中有多少个可变的变量(有时候,有些参数是固定的,不会发生变化)。比如说这里我们只有一个参数,我们就生成一个一维表。
2、找到已知条件。动态规划的题目都是可以从一些给定的点,逐步得到最后的结果,比如说给定0,我们可以推到1,得到1,可以推出2,得到2,可以推出 3,之后逐步获得答案。那么我们需要如何得到这些已知条件。
答案就是我们可以看basecase,也就是dfs递归的出口,我们观察到当i < 0 的时候,对应的结果都是0。另外我们观察到我们需要两个参数,所以我们取出 -1 和 -2 得到 dfs(0)
dfs(0)= max(dfs(-1),dfs(-2) + nums[0])= 1
dfs(1)= max(dfs(0),dfs(-1) + nums[1]
。。。。。
依次可以得到最终的dfs(4),这个dfs(4)就是我们需要的最终结果。

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

超过100%

我们声明可一个结果数组,这个结果数组是一维的,正如我们上面讨论的一样,可变参数有几个,就声明一个几维的数组,初始的时候将数组的第一个和第二个设置成0,之后依次填充数组,返回最后一个结果。

希望对看到这里的你有一点点帮助!

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

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

相关文章

【分布式数据仓库Hive】Hive的安装配置及测试

目录 一、数据库MySQL安装 1. 检查操作系统是否有MySQL安装残留 2. 删除残留的MySQL安装&#xff08;使用yum&#xff09; 3. 安装MySQL依赖包、客户端和服务器 4. MySQL登录账户root设置密码 5. 启动MySQL服务 6. 登录MySQL&#xff0c;进入数据库操作提示符 7. 授权H…

SpringBoot 启动流程六

SpringBoot启动流程六 这句话是创建一个上下文对象 就是最终返回的那个上下文 我们这个creatApplicationContext方法 是调用的这个方法 传入一个类型 我们通过打断点的方式 就可以看到context里面的东西 加载容器对象 当我们把依赖改成starter-web时 这个容器对象会进行…

深度解析Java世界中的对象镜像:浅拷贝与深拷贝的奥秘与应用

在Java编程的浩瀚宇宙中&#xff0c;对象拷贝是一项既基础又至关重要的技术。它直接关系到程序的性能、资源管理及数据安全性。然而&#xff0c;提及对象拷贝&#xff0c;不得不深入探讨其两大核心类型&#xff1a;浅拷贝&#xff08;Shallow Copy&#xff09;与深拷贝&#xf…

等保2.0标准相比之前的有哪些重大变化?

在数字化的浪潮中&#xff0c;网络安全如同一艘坚固的航船&#xff0c;承载着国家与民族的希望&#xff0c;驶向信息化的彼岸。等级保护制度&#xff08;等保&#xff09;作为中国网络安全的守护神&#xff0c;经过岁月的洗礼与智慧的积淀&#xff0c;迎来了等保2.0的时代&…

Android仿天眼查人物关系图

效果图预览 绘制思路 这里使用了中学解析几何知识 XPoint OPointX OPointXcosθ&#xff1b; YPoint OPointY OPointYsinθ&#xff1b; canvas.drawText(lists.get(i).getName(), XPoint (float) Math.cos(pere * i 5) * radius[i % radius.length] - 30, YPoint (fl…

C语言 | Leetcode C语言题解之第213题打家劫舍II

题目&#xff1a; 题解&#xff1a; int robRange(int* nums, int start, int end) {int first nums[start], second fmax(nums[start], nums[start 1]);for (int i start 2; i < end; i) {int temp second;second fmax(first nums[i], second);first temp;}retur…

昇思25天学习打卡营第9天|保存与加载

保存与加载 在训练网络模型的过程中&#xff0c;保存中间和最后结果可以用来微调和后续的模型推理与部署。 # 首先定义一个模型 def network():model nn.SequentialCell(nn.Flatten(),nn.Dense(28*28, 512),nn.ReLU(),nn.Dense(512, 512),nn.ReLU(),nn.Dense(512, 10))retur…

Hive-存储-文件格式

一、前言 数据存储是Hive的基础&#xff0c;选择合适的底层数据存储格式&#xff0c;可以在不改变Hql的前提下得到大的性能提升。类似mysql选择适合场景的存储引擎。 Hive支持的存储格式有 文本格式&#xff08;TextFile&#xff09; 二进制序列化文件 &#xff08;SequenceF…

(vue)el-tabs选中最后一项后更新数据后无法展开

(vue)el-tabs选中最后一项后更新数据后无法展开 效果&#xff1a; 原因&#xff1a;选中时绑定的值在数据更新后找不到 思路&#xff1a;更新数据时把选中的v-model的属性赋为初始值 写法&#xff1a; <el-form-item label"字段选择"><el-tabsv-model&qu…

相关款式1111

一、花梨木迎客松 1. 风速打单 发现只有在兄弟店铺有售卖 六月份成交订单数有62笔 2. 生意参谋 兄弟店铺商品访客数&#xff1a;3548&#xff0c;支付件数&#xff1a;95件 二. 竹节茶刷&#xff08;引流&#xff09; 1. 风速打单 六月订单数有165笔 兄弟&#xff1a;…

喜报 | 怿星携高性价比国产方案亮相IAEIS峰会并荣获“优秀创新产品奖”

近日&#xff0c;由深圳市汽车电子行业协会主办的主题为&#xff1a;“布局全球产业链&#xff0c;促进智能网联汽车产业高质量发展”IAEIS 2024第十三届国际汽车电子产业峰会”暨“2023年度汽车电子科学技术奖”颁奖典礼在深圳隆重举行。 怿星科技携高性价比的「车载网络通信 …

【45 Pandas+Pyecharts | 去哪儿海南旅游攻略数据分析可视化】

文章目录 &#x1f3f3;️‍&#x1f308; 1. 导入模块&#x1f3f3;️‍&#x1f308; 2. Pandas数据处理2.1 读取数据2.2 查看数据信息2.3 日期处理&#xff0c;提取年份、月份2.4 经费处理2.5 天数处理 &#x1f3f3;️‍&#x1f308; 3. Pyecharts数据可视化3.1 出发日期_…

PyCharm中如何将某个文件设置为默认运行文件

之前在使用JetBrain公司的另一款软件IDEA的时候&#xff0c;如果在选中static main函数后按键altenter可以默认以后运行Main类的main函数。最近在使用PyCharm学习Python&#xff0c;既然同为一家公司的产品而且二者的风格如此之像&#xff0c;所以我怀疑PyCharm中肯定也有类似的…

获取VC账号,是成为亚马逊供应商的全面准备与必要条件

成为亚马逊的供应商&#xff0c;拥有VC&#xff08;Vendor Central&#xff09;账号&#xff0c;是众多制造商和品牌所有者的共同目标。这不仅代表了亚马逊对供应商的高度认可&#xff0c;也意味着获得了更多的销售机会和更广阔的市场前景。 全面准备与必要条件是获取VC账号的关…

中科院分区表中被“On Hold”的TOP期刊!爱思唯尔会对中国学者下手吗?

关注GZH【欧亚科睿学术】&#xff0c;GET完整版2023JCR分区列表&#xff01; ↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 目前&#xff0c;共37本期刊被科睿唯安标记为“On Hold”状态&#xff0c;其中包含5本中科院TOP期刊&#xff0c;主要来自Elsevier出版社旗下。…

简单配置VScode轻量级C++竞赛环境

1. 安装拓展 Chinese是中文&#xff0c;需要重启才可以运行&#xff0c;C/C拓展只是进行语法代码提示&#xff0c;不需要进行任何配置修改&#xff0c;默认即可。 2. 创建文件 如上图创建好各级文件夹&#xff0c;其中C是工作文件夹&#xff0c;.vscode是配置文件夹&#xff0…

前端根据目录生成模块化路由routes

根据约定大于配置的逻辑&#xff0c;如果目录结构约定俗成&#xff0c;前端是可以根据目录结构动态生成路由所需要的 route 结构的&#xff0c;这个过程是要在编译时 进行&#xff0c;生成需要的代码&#xff0c;保证运行时的代码正确即可 主流的打包工具都有对应的方法读取文…

Renderless 思想正在影响前端开发

本文由前端小伙伴方长_beezen 原创。欢迎大家踊跃投稿。 原文链接&#xff1a;https://juejin.cn/post/7385752495535472655 前言 截止到 2024 年&#xff0c;跨端应用开发所需要考虑的兼容性&#xff0c;已经涵盖了框架、平台和设备类型等多个方面&#xff0c;例如&#xff1…

【Matlab 路径优化】基于蚁群算法的XX市旅游景点线路优化系统

基于蚁群算法的XX市旅游景点线路优化系统 &#xff08;一&#xff09;客户需求&#xff1a; ①考虑旅游景点的空间分布、游客偏好等因素&#xff0c;实现了旅游线路的智能规划 ②游客选择一景点出发经过所要游览的所有景点只一次&#xff0c;最后回到出发点的前提下&#xf…