当前位置: 首页 > news >正文

【LeetCode】剑指 Offer(24)

目录

题目:剑指 Offer 47. 礼物的最大价值 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过啦!!!

写在最后:


题目:剑指 Offer 47. 礼物的最大价值 - 力扣(Leetcode)

题目的接口:

class Solution {
public:int maxValue(vector<vector<int>>& grid) {}
};

解题思路:

这是一道动态规划的题目,

具体思路如下:

我们将这个问题分解成一个个小问题:

看一下这个例子:

如果第一行的2是终点,那么他的最大路径是dp[0][0] + dp[0][1];

如果第二行的1是终点,那么他的最大路径是dp[1][0] + dp[0][0];

然后,

我们将这两个位置的数值,改成dp[0][0] + dp[0][1]、dp[1][0] + dp[0][0],

如下图:

 那么以此类推:

如果dp[0][2]是终点,dp[0][2]就等于 dp[0][1] + dp[0][2];

如果dp[2][0]是终点,dp[2][0]就等于 dp[1][0] + dp[2][0];

如果dp[1][1]是终点,dp[1][1]就等于 max(dp[0][1], dp[1][0]) + dp[1][1]。

按照这个规律走,最后,右下角的那个就是最大路径的值。 

这就是将一个大的问题,拆解成一个个小问题解决。

代码:

class Solution {
public:int maxValue(vector<vector<int>>& grid) {//这是棋盘的行和列int row = grid.size();int col = grid[0].size();//这是棋盘第一行每一格的路径的最大值计算for(int i = 1; i < col; i++){grid[0][i] = grid[0][i - 1] + grid[0][i];}//这是棋盘第一列每一格的路径的最大值计算for(int i = 1; i < row; i++){grid[i][0] = grid[i - 1][0] + grid[i][0];}//这是棋盘剩余位置的每一格作为终点的路径最大值计算for(int i = 1; i < row; i++){for(int j = 1; j < col; j++){grid[i][j] = max(grid[i - 1][j], grid[i][j - 1]) + grid[i][j];}}//最后返回右下角的路径最大值return grid[row - 1][col - 1];}
};

过啦!!!

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果喜欢本文的话,欢迎点赞和评论,写下你的见解。

如果想和我一起学习编程,不妨点个关注,我们一起学习,一同成长。

之后我还会输出更多高质量内容,欢迎收看。

http://www.lryc.cn/news/39623.html

相关文章:

  • javaEE 初阶 — CSS 元素的显示模式与盒模型
  • 新星计划-我为什么要写博客?写博客的意义是什么
  • 嵌入式学习笔记——STM32的USART收发字符串及串口中断
  • 数据分析之Pandas(1)
  • 17、江科大stm32视频学习笔记——USART串口协议和USART串口外设
  • leetcode:有效地括号
  • 四等分list
  • php连接sqlserver数据库
  • The 2019 China Collegiate Programming Contest Harbin Site F. Fixing Banners
  • Maven的下载和配置
  • 服务高并发、高性能、高可用实现方案
  • uniCloud在线升级APP配置教程
  • idea常用的快捷键
  • 全志V85x硬件设计大赛作品精选第一期,快来Pick你心目中的最佳方案
  • 博客系统(界面设计)
  • 素材要VIP咋整?看python大展神通
  • [ vulnhub靶机通关篇 ] 渗透测试综合靶场 DC-1 通关详解 (附靶机搭建教程)
  • 软件测试文档编写步骤
  • 重新认识下网页水印
  • Unity脚本练习
  • 二十分钟带你了解JVM性能调优与实战进阶
  • 对比应用层和内核层区别
  • Hadoop服役新服务器
  • YOLOv8详解 【网络结构+代码+实操】
  • Visual Studio Code 1.76 发布
  • Vulnhub靶场----3、DC-3.2
  • Windows电脑密码忘记解决方法
  • ChatGPT相关技术必读论文100篇(2.27日起,几乎每天更新)
  • 【算法】算法题解---电话号码的字符组合
  • 提高上限之数学学习——数制转换及MECE原则学习