代码随想录训练营Day30:动态规划2

1.62不同路径

  1. dp[i][j]数组的定义:到达坐标(i,j)所需要的路径个数。
  2. 递推公式:dp[i][j] = dp[i-1][j]+dp[i][j-1];//到达(i,j)的上一步只能是从上面到或者左边到
  3. 初始化:对于到达(i,0)或者(0,j)只有一条路可以走。
  4. 遍历顺序:因为dp[i][j]与上方和左方的数据有关,所以双重遍历按照从上到下,再从左到右。
class Solution {
public:int uniquePaths(int m, int n) {vector<vector<int>> dp(m,vector<int>(n,0));for(int i = 0;i < m;i++) dp[i][0] = 1;for(int j = 0;j < n;j++) dp[0][j] = 1;for(int i = 1;i < m;i++){for(int j = 1;j < n;j++){dp[i][j] = dp[i-1][j]+dp[i][j-1];}}return dp[m-1][n-1];}
};

2.63不同路径二

  1. dp[i][j]数组的定义:到达坐标(i,j)所需要的路径个数。
  2. 递推公式:dp[i][j] = dp[i-1][j]+dp[i][j-1];//到达(i,j)的上一步只能是从上面到或者左边到,这里需要考虑的情况就是如果当前的位置是障碍的话,那么dp[i][j] = 0;因为怎样都无法走到这里
  3. 初始化:对于第一行和第一列在未遇到障碍前设置为1,如果遇到了障碍,那么从这个开始全都是变为0.
  4. 遍历顺序:因为dp[i][j]与上方和左方的数据有关,所以双重遍历按照从上到下,再从左到右。
class Solution {
public:int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {int m = obstacleGrid.size();int n = obstacleGrid[0].size();vector<vector<int>> dp(m,vector<int>(n,0));//到达(i,j)的路径的条数for(int i = 0;i < m && obstacleGrid[i][0] == 0;i++) dp[i][0] = 1;for(int j = 0;j < n && obstacleGrid[0][j] == 0;j++) dp[0][j] = 1;for(int i = 1;i < m;i++){for(int j = 1;j < n;j++){if(obstacleGrid[i][j] == 1){dp[i][j] == 0;}else{dp[i][j] = dp[i-1][j]+dp[i][j-1];}}}return dp[m-1][n-1];}
};

3.343整数拆分

1.dp[i]:拆分成k>=2个之后的最大乘积

2.递推公式:dp[i] = max(max(dp[i],j*dp[i-j]),j*(i-j));//j*(i-j)代表的是拆分成两个,j*dp[i-j]代表的是拆分成k+1>2个的还有一个就是dp[i]代表的相当于前面的历史最大值。

为什么是这三个呢?因为dp[i-j]代表的拆分至少是2个再乘以j那么至少就是三个了,无法覆盖两个的情况,所以得把两个的单独提出来,dp[i]是因为我们要找到这一部分的最大值。

为什么只需要遍历一半呢?

因为根据数学知识,拆分成n个相近的值最大,而拆分的个数至少是2个,所以只需要遍历到i/2即可。

3.初始化:根据给定的定义初始化即可。

4.遍历顺序:我们可以看到递推公式可以知道我们需要从小到大遍历。

class Solution {
public:int integerBreak(int n) {//dp[i]:拆分成k个的最大的乘积vector<int> dp(n+1,1);//默认情况下dp[0]=1,dp[1] = 1,dp[2] =1;这个里面默认是有两个及以上的for(int i=3;i<=n;i++){for(int j =1;j<=i/2;j++){//只需要遍历一半就行dp[i] = max(max(dp[i],j*dp[i-j]),j*(i-j));}}return dp[n];}
};

4.96不同的搜索二叉树

1.dp[i]:节点个数为i的搜索二叉树的个数

2.递推公式:dp[i] += dp[j]*dp[i-j-1];我们将其分成三个部分:根节点(1):左子树(j),右子树(i-j-1),由于左右子树互不影响,要想求解此时对应节点分布情况下的搜索二叉树个数,所以需要用乘法来叠加。

3.初始化:默认情况下dp[0] = 1,dp[1] = 1;

4.遍历顺序:根据递推公式可以知道,其对应的和前面的值相关,所以遍历顺序应该是从小到大进行遍历。

class Solution {
public:int numTrees(int n) {vector<int> dp(n+1,0);//dp数组代表的是i个节点的二叉搜索树的和dp[0] = 1; dp[1] = 1;//分为n种情况假设有i个节点,一个作为根节点,其中j个作为一个整体,i-j-1作为另外一个整体,那么这样的一共有多少种排序的方式//dp[j]*dp[i-j]//默认情况下dp[0] = 1,dp[1] = 1for(int i = 2;i<=n;i++){for(int j = 0;j<i;j++){dp[i] += dp[j]*dp[i-j-1];}}/*for(int i = 1;i <= n;i++) {for(int j = 1;j <= i;j++){dp[i] += dp[j-1]*dp[i-j];}}*/return dp[n];}
};

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

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

相关文章

Leaflet.canvaslabel在Ajax异步请求时bindPopup无效的解决办法

目录 前言 一、场景重现 1、遇到问题的代码 2、问题排查 二、通过实验验证猜想 1、排查LayerGroup和FeatureGroup 2、排查Leaflet.canvaslabel.js 三、柳暗花明又一村 1、点聚类的办法 2、歪打正着 总结 前言 在上一篇博客中介绍了基于SpringBoot的全国风景区WebGIS按…

Flutter 中的 Card 小部件:全面指南

Flutter 中的 Card 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;Card 是一个用于呈现内容的容器&#xff0c;它带有圆角边缘和阴影效果&#xff0c;常用于展示信息块&#xff0c;如用户头像、相册、笔记或任何需要突出显示的内容。Card 小部件提供了一种简单而直观的…

unity---常用API

1. Vector3&#xff1a;结构体由x、y、z这3个数值组成&#xff0c;表示一个向量 magnitude变量返回该向量的长度normalized变量返回 magnitude 为 1 时的该向量zero静态变量Vector3(0, 0, 0)one静态变量Vector3(1, 1, 1)forward静态变量Vector3(0, 0, 1)back静态变量Vector3(0…

Flutter 中的 Stack 小部件:全面指南

Flutter 中的 Stack 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;Stack 是一个用于叠加多个小部件的布局小部件。它允许你将多个小部件重叠放置&#xff0c;通过控制每个小部件的位置和大小&#xff0c;你可以创建出复杂的布局效果&#xff0c;如徽章图标、对话框、…

pandas DataFrame 常用遍历方法

在Pandas中&#xff0c;可以使用多种方法遍历DataFrame中的数据。以下是几种常见的方法&#xff1a; 基于索引遍历DataFrame的每一行。 基于行号遍历DataFrame的每一行, 该方式通过行号获取行数据信息&#xff0c;格式为Series&#xff0c;无法获取改行的index信息。 使用iterr…

1.8. 离散时间鞅-无界停时定理与随机游走

无界停时定理与随机游走 无界停时定理与随机游走1. 无界停时定理1.1. 一致可积1.2. 非一致可积2. 应用于随机游动-鞅方法2.1. 随机游走构造的鞅2.2. 对称简单随机游走无界停时定理与随机游走 1. 无界停时定理 本节给出一致可积下鞅的无界停时定理,说明一致可积下鞅的停止过程…

Agent AI智能体:未来社会的角色、发展与挑战

Agent AI智能体在未来社会中的角色、发展路径以及可能带来的挑战是一个非常值得关注的话题。让我们来深入探讨一下这些方面。 1. 角色与应用场景 Agent AI智能体是指具有自主决策能力和执行能力的人工智能系统&#xff0c;它们可以代表个人或组织执行各种任务和活动。在未来社…

大学课程中的算法java实现【学习算法】

大学课程中的算法java实现【学习算法】 前言前言推荐离散数学Warshall算法 P102可达性矩阵 P187欧拉图 Fleury算法 P201最小生成树 P234哈夫曼数 P240 数据结构与算法计算机操作系统最后 前言 这是陈旧已久的草稿2023-04-22 23:20:38 这是准备自己用java实现大学课程中所有遇…

免疫优化算法(Immune Optimization Algorithm)

注意&#xff1a;本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 &#xff08;[www.aideeplearning.cn]&#xff09; 算法背景 免疫算法是一种模拟生物免疫系统的智能优化算法。想象一下&#xff0c;当我们的身体遇到病毒或细菌侵袭时&#xff0c;免疫系统会启动…

mysql 事物

MySQL中的事务&#xff08;Transaction&#xff09;是一个确保数据完整性和一致性的重要概念。它将一组SQL操作捆绑在一起&#xff0c;当作一个单一的工作单元来执行。事务具备以下四个关键特性&#xff0c;即ACID特性&#xff1a; 原子性&#xff08;Atomicity&#xff09;&am…

DHCP原理

什么是DHCP DHCP (Dynamic Host Configuration Protocol,动态主机配置协议&#xff09;是由Internet工作任务小组设计开发的&#xff0c;专门用于为TCP/IP网络中的计算机自动分配TCP/IP参数的协议&#xff0c;是一个应用层协议&#xff0c;使用UDP的67和68端口。 DHCP的前身是B…

Windows下安装 Emscripten 详细过程

背景 最近研究AV1编码标准的aom编码器&#xff0c;编译的过程中发现需要依赖EMSDK&#xff0c;看解释EMSDK就是Emscripten 的相应SDK&#xff0c;所以此博客记录下EMSDK的安装过程&#xff1b;因为之前完全没接触过Emscripten 。 Emscripten Emscripten 是一个用于将 C 和 …

[hpssupfast@mailfence.com].Elbie勒索病毒如何恢复数据和预防

[hpssupfastmailfence.com].Elbie是一种新型勒索病毒,快速恢复重要数据请添加技术服务号(safe130)。以下是关于elbie勒索病毒的详细信息&#xff1a; 病毒介绍&#xff1a; elbie勒索病毒&#xff0c;也称为PHOBOS勒索软件&#xff0c;它通过加密文件并要求支付赎金以恢复对文…

涉案财物管理系统|DW-S405系统全国都有案例

涉案财物管理系统&#xff08;智财物&#xff1a;DW-S404&#xff09;是一套成熟系统&#xff0c;依托互3D技术、云计算、大数据、RFID技术、数据库技术、AI、视频分析技术对涉密载体进行统一管理、分析的信息化、智能化、规范化的系统。 涉案财物管理系统主要实现对涉案物品进…

RisingWave基本操作

什么是RisingWave RisingWave 是一款基于 Apache 2.0 协议开源的分布式流数据库。RisingWave 让用户使用操作传统数据库的方式来处理流数据。通过创建实时物化视图&#xff0c;RisingWave 可以让用户轻松编写流计算逻辑&#xff0c;并通过访问物化视图来对流计算结果进行及时、…

分享一个处理大文件效率拉满的神器

&#x1f3c3;‍♂️ 微信公众号: 朕在debugger© 版权: 本文由【朕在debugger】原创、需要转载请联系博主&#x1f4d5; 如果文章对您有所帮助&#xff0c;欢迎关注、点赞、转发和订阅专栏&#xff01; 前言 系统当天有些表的数据需要恢复成前一天的样子&#xff0c;幸好有…

Rpcx (一):详解【介绍、基础示例 demo】

一.rpcx介绍 1.1 rpc是什么 远程过程调用的通信协议。该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而程序员无需额外地为这个交互作用编程。如果涉及的软件采用面向对象编程,那么远程过程调用亦可称作远程调用或远程方法调用。简单地说就是能使应用像调用本地…

【动态规划】子序列问题I|最长递增子序列|摆动序列|最长递增子序列的个数|最长数对链

一、最长递增子序列 300. 最长递增子序列 算法原理&#xff1a; &#x1f4a1;细节&#xff1a; 1.注意子序列和子数组的区别&#xff1a; (1)子序列&#xff1a;要求顺序是固定的&#xff08;要求没那么高&#xff0c;所以子序列就多一些&#xff09; (2)子数组&#xff1a;要…

2024年深圳市教师招聘报名流程(建议电脑)

2024年深圳市教师招聘报名流程&#xff08;建议电脑&#xff09; #深圳教师招聘 #深圳教招 #深圳教师招聘考试 #教师招聘报名照片处理 #深圳教师招聘笔试

(Java)心得:LeetCode——19.删除链表的倒数第 N 个节点

一、原题 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], n 2 输出&#xff1a;[1,2,3,5]示例 2&#xff1a; 输入&#xff1a;head [1], n 1 输出&#xff1a;[]示例 3&…