力扣每日一题2023.7.13

这篇具有很好参考价值的文章主要介绍了力扣每日一题2023.7.13。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目:

力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

示例:

力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

分析:

给我们一个矩阵,我们需要找出一条路径从矩阵第一层(索引为0)到达矩阵最后一层,并且使得路径上的数值之和最小.

如果是老手,那么应该一眼就能看出来可以使用动态规划,如果看不出来,那我们接下来一起分析分析.

首先我们先不要搞这么复杂,以示例1为例,我们就假设矩阵只有两层,先忽略掉第三层(最后一层):

力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

那么我们从第一层到达最后一层(第二层)的最短路径和是多少呢.

如果我到达的是第二层的6,那么我是可以从第一层的2和1两个地方到达,所以我们如果到达的地方是6,则最短路径和是1+6=7.

如果我到达的是第二层的5,那么可以从第一层的2和1和3一共三个地方到达,即到达第二层的5的最短路径和为1+5=6.同理,到达第二层的4的最短路径和为1+4=5.

所以如果是上述两层的矩阵,我们得到的最短路径和是5(从第一层到达最后一层的4).

我们现在再把第三层加入进来,是这样的:

力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

 和我们刚才只有两层的矩阵相比,仅仅是多了一层,我们仍然可以套用刚才的计算公式,现在我们把刚刚推导出来的到达第二层的最短路径和覆盖掉原始的数值,是这样的:力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

 我们可以接着利用推导过的第二层来接着推导第三层,最后是这样的:

 力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展

所以我们遍历最后推断完毕的最后一层可以得出示例1的最小路径和是13.

这类可以将大问题拆分成多个有关联性的小问题的题目,我们都可以使用动态规划.并且动态规划大多离不开贪心思想.

根据以上思路我们不难写出代码,但是有一点需要注意一下,就是在遍历矩阵每层的首位元素的时候要注意不能下标越界,具体可以参考下面的代码.

完整代码+结果如下:

class Solution {
public:
    int minFallingPathSum(vector<vector<int>>& matrix) {
        int n=matrix.size();
        if(n==1) return matrix[0][0];
        for(int i=1;i<n;i++){
            //矩阵每行的开头单独拎出来,因为 0-1 会下标越界
            matrix[i][0]+=min(matrix[i-1][0],matrix[i-1][1]);
            for(int j=1;j<n-1;j++){
                //找出上一层的最多相隔一列的最小路径和,再与本层元素相加,得到本层的最小路径和
                matrix[i][j]+=min(min(matrix[i-1][j-1],matrix[i-1][j]),matrix[i-1][j+1]);
            }
            //矩阵每行的结尾也单独拎出来,因为 n+1 会下标越界
            matrix[i][n-1]+=min(matrix[i-1][n-1],matrix[i-1][n-2]);
        }
        int res=matrix[n-1][0];
        //遍历最后一层得出最小路径和
        for(int i=1;i<n;i++){
            res=min(res,matrix[n-1][i]);
        }
        return res;
    }
};

力扣每日一题2023.7.13,力扣每日一题,leetcode,算法,职场和发展文章来源地址https://www.toymoban.com/news/detail-557525.html

到了这里,关于力扣每日一题2023.7.13的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Leetcode每日一题:931. 下降路径最小和(2023.7.13 C++)

    Leetcode每日一题:931. 下降路径最小和(2023.7.13 C++)

    目录 931. 下降路径最小和 题目描述: 实现代码与解析: 动态规划 原理思路:         给你一个  n x n  的  方形  整数数组  matrix  ,请你找出并返回通过  matrix  的 下降路径   的   最小和  。 下降路径  可以从第一行中的任何元素开始,并从每一行中选择一个元素

    2024年02月16日
    浏览(14)
  • 2023-08-15力扣每日一题

    链接: 833. 字符串中的查找与替换 题意: n组操作,其中第i组: 检查 子字符串 sources[i] 是否出现在 原字符串 s 的索引 indices[i] 处。 如果没有出现, 什么也不做 。 如果出现,则用 targets[i] 替换 该子字符串。 所有替换操作必须 同时 发生,这意味着替换操作不应该影响彼此

    2024年02月12日
    浏览(9)
  • 2023-08-24力扣每日一题

    链接: 1267. 统计参与通信的服务器 题意: 同行同列可以发生通信,求能发生通信的机器数量 解: 标记每行/每列的机器个数即可 实际代码: 限制: m == grid.length n == grid[i].length 1 = m = 250 1 = n = 250 grid[i][j] == 0 or 1

    2024年02月11日
    浏览(14)
  • 2023-07-12力扣每日一题

    链接: 2544. 交替数字和 题意: 一个数字字符串,根据符号求和,符号规律+ - + - +… 解: 简单题,遍历 实际代码: 手写: 函数!小子: 限制: 1 = n = 109

    2024年02月15日
    浏览(17)
  • 2023-08-26力扣每日一题

    链接: 228. 汇总区间 题意: 升序数组找连续区间 解: 简单遍历题 实际代码: 限制: 0 = nums.length = 20 -231 = nums[i] = 231 - 1 nums 中的所有值都 互不相同 nums 按升序排列

    2024年02月11日
    浏览(8)
  • 2023-07-14力扣每日一题

    链接: 979. 在二叉树中分配硬币 题意: 一个二叉树,n个节点,节点 权值总和 为n, 每次 可以 相邻节点 间移动 1 权值 求让每个节点都为1的最少次数 解: 给定了一个树的结构体,先整一手DFS/BFS,n不大,随便莽莽 首先每个节点只需要剩下1,而且可以知道 叶子节点 如果不

    2024年02月16日
    浏览(12)
  • 2023-08-29力扣每日一题

    链接: 823. 带因子的二叉树 题意: 用给的数字建二叉树,要求父节点是子节点的乘积 解: 乐了 1500ms+30MB //注释版120ms+18MB 实际代码: 限制: 1 = arr.length = 1000 2 = arr[i] = 109 arr 中的所有值 互不相同

    2024年02月11日
    浏览(13)
  • 2023-08-22力扣每日一题

    链接: 849. 到最近的人的最大距离 题意: 找一个离人最远的位置 解: 每个位置都用左边的人和右边的人更新一遍距离即可 实际代码: 限制: 2 = seats.length = 2 * 104 seats[i] 为 0 或 1 至少有一个 空座位 至少有一个 座位上有人

    2024年02月11日
    浏览(11)
  • 2023-09-08力扣每日一题

    链接: 2651. 计算列车到站时间 题意: 不看日期只看时间 解: ? 实际代码: 限制: 1 = arrivaltime 24 1 = delayedTime = 24

    2024年02月09日
    浏览(10)
  • 2023-08-23力扣每日一题

    链接: 1782. 统计点对的数目 题意: 给n个点和m条无向边(可重复),q个查询 定义 edge[a] 为一个点是a的边数量,定义 ret[a,b] 是 edge[a]+edge[b]-(a与b的边) q个查询q个答案,第i次查询值 val[i] ,求所有的 1=ab=n 条件下有多少 ret[a,b]val[i] 解: TLE卡47了 看了评论区用空间换时间,

    2024年02月10日
    浏览(12)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包