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

免费企业网站建设要求在线外链发布工具

免费企业网站建设要求,在线外链发布工具,设计的拼音,建个网站做网络推广要花多少钱【LetMeFly】2304.网格中的最小路径代价:DP 力扣题目链接:https://leetcode.cn/problems/minimum-path-cost-in-a-grid/ 给你一个下标从 0 开始的整数矩阵 grid ,矩阵大小为 m x n ,由从 0 到 m * n - 1 的不同整数组成。你可以…

【LetMeFly】2304.网格中的最小路径代价:DP

力扣题目链接:https://leetcode.cn/problems/minimum-path-cost-in-a-grid/

给你一个下标从 0 开始的整数矩阵 grid ,矩阵大小为 m x n ,由从 0m * n - 1 的不同整数组成。你可以在此矩阵中,从一个单元格移动到 下一行 的任何其他单元格。如果你位于单元格 (x, y) ,且满足 x < m - 1 ,你可以移动到 (x + 1, 0), (x + 1, 1), ..., (x + 1, n - 1) 中的任何一个单元格。注意: 在最后一行中的单元格不能触发移动。

每次可能的移动都需要付出对应的代价,代价用一个下标从 0 开始的二维数组 moveCost 表示,该数组大小为 (m * n) x n ,其中 moveCost[i][j] 是从值为 i 的单元格移动到下一行第 j 列单元格的代价。从 grid 最后一行的单元格移动的代价可以忽略。

grid 一条路径的代价是:所有路径经过的单元格的 值之和 加上 所有移动的 代价之和 。从 第一行 任意单元格出发,返回到达 最后一行 任意单元格的最小路径代价

 

示例 1:

输入:grid = [[5,3],[4,0],[2,1]], moveCost = [[9,8],[1,5],[10,12],[18,6],[2,4],[14,3]]
输出:17
解释:最小代价的路径是 5 -> 0 -> 1 。
- 路径途经单元格值之和 5 + 0 + 1 = 6 。
- 从 5 移动到 0 的代价为 3 。
- 从 0 移动到 1 的代价为 8 。
路径总代价为 6 + 3 + 8 = 17 。

示例 2:

输入:grid = [[5,1,2],[4,0,3]], moveCost = [[12,10,15],[20,23,8],[21,7,1],[8,1,13],[9,10,25],[5,3,2]]
输出:6
解释:
最小代价的路径是 2 -> 3 。 
- 路径途经单元格值之和 2 + 3 = 5 。 
- 从 2 移动到 3 的代价为 1 。 
路径总代价为 5 + 1 = 6 。

 

提示:

  • m == grid.length
  • n == grid[i].length
  • 2 <= m, n <= 50
  • grid 由从 0m * n - 1 的不同整数组成
  • moveCost.length == m * n
  • moveCost[i].length == n
  • 1 <= moveCost[i][j] <= 100

方法一:DP

从倒数第二行开始往第一行遍历:

  • 对于这一行的每一个元素:
    • 计算出 从下一行的所有元素中来到这一行,增加值最小的那个
  • 这个元素加上下一行来的最小增加量

最终返回第一行中的最小元素即为答案。

  • 时间复杂度 O ( n m 2 ) O(nm^2) O(nm2),其中 s i z e ( g r i d ) = n × m size(grid)=n\times m size(grid)=n×m n n n m m m列)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
class Solution {
public:int minPathCost(vector<vector<int>>& grid, vector<vector<int>>& moveCost) {int n = grid.size(), m = grid[0].size();for (int i = n - 2; i >= 0; i--) {for (int j = 0; j < m; j++) {int m_ = 100000000;for (int k = 0; k < m; k++) {m_ = min(m_, grid[i + 1][k] + moveCost[grid[i][j]][k]);}grid[i][j] += m_;}}return *min_element(grid[0].begin(), grid[0].end());}
};
Python
# from typing import Listclass Solution:def minPathCost(self, grid: List[List[int]], moveCost: List[List[int]]) -> int:n, m = len(grid), len(grid[0])for i in range(n - 2, -1, -1):for j in range(m):m_ = 100000000for k in range(m):m_ = min(m_, grid[i + 1][k] + moveCost[grid[i][j]][k])grid[i][j] += m_return min(grid[0])

同步发文于CSDN,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/134563145

http://www.mmbaike.com/news/106266.html

相关文章:

  • 手机网站开发+图库类网站怎么做推广
  • 做书app下载网站有哪些免费友情链接网站
  • 简单三栏网站手机cpu性能增强软件
  • 建筑标准下载网站网络推广网络营销和网站推广的区别
  • 静态网站挂马百度推广怎么做最好
  • 轻量应用服务器可以做网站吗英文站友情链接去哪里查
  • wordpress建站教程主题百度一下首页网页百度
  • 国内扁平化网站百度seo搜搜
  • 想要去网站做友情链接怎么发邮件营销推广的特点
  • 做外卖有哪些网站有哪些百度帐号登录
  • 网站涉及敏感视频等该怎么做seo服务 文库
  • 广州建筑集团网站seo成创网络
  • 大型网站 空间网络广告投放网站
  • 学院管理网站建设谷歌搜索优化
  • 做网站建设怎么介绍自己网站设计开发网站
  • 常州网站制作多少钱seo北京公司
  • 简述一下网站建设流程百度模拟点击软件判刑了
  • 网站是哪家公司做的百度推广怎么推
  • 婚纱网站策划书模板公众号免费推广平台
  • wordpress企业建站油烟机seo关键词
  • 网站建设品牌公司推荐电商运营模式
  • 网站建设找哪个谷歌seo推广培训班
  • 成都集团网站建设广州网站优化多少钱
  • 网站建设销售兼职合同青岛seo网站关键词优化
  • 有赞可以做独立网站吗杭州产品推广服务公司
  • 四博互联做的网站免费营销软件网站
  • 从哪里找网站网站建设 全网营销
  • 微软雅黑做网站某个网站seo分析实例
  • 做解析视频网站违法莫中国国家人事人才培训网证书查询
  • 城阳网站建设培训谷歌搜索引擎免费入口 香港