力扣每日一题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++)

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

    2024年02月16日
    浏览(38)
  • 2023-07-16力扣每日一题

    链接: 834. 树中距离之和 题意: 给定一个树,有n个节点,需要得到每个节点与其他节点的距离和 解: 还以为是弗洛伊德,一看范围3E4直接晕倒 想了四个小时,实在是想不出来了,看了一下评论里的转移公式 设 DP[i] 为节点 i 与其他节点的距离和, DP[F] 是节点 i 的父节点与

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

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

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

    链接: 1281. 整数的各位积和之差 题意: 十进制每一位的积减去每一位的和 解: 十进制位处理 实际代码: 限制: 1 = n = 10^5

    2024年02月13日
    浏览(30)
  • 2023-09-01力扣每日一题

    链接: 2240. 买钢笔和铅笔的方案数 题意: 一共total元,两种笔分别cost1和cost2元,求能买的的笔的所有情况,不要求花光钱 解: 枚举其中一个数字就行 实际代码: 限制: 1 = total, cost1, cost2 = 106

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

    链接: 2511. 最多可以摧毁的敌人城堡数目 题意和解 : 阅读理解题,要从1到-1或-1到1,中间只能有0,求最多能有多少0 实际代码: 限制: 1 = forts.length = 1000 -1 = forts[i] = 1

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

    链接: https://leetcode.cn/problems/maximum-alternating-subsequence-sum/ 题意: 给定一个数组,求一个子序列,使这个子序列的 奇数位和-偶数位和 最大(下标从1开始的话|反正第一个数是+) 解: 找下坡,曲折处两个分下坡大于一个总下坡(如图) 实际代码: 思维: DP?: 限制: 1 = nu

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

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

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

    链接: 18. 四数之和 题意: 一个数组n,一个目标值t,在数组内找四个数字和等于t,求能有多少种组合 解: 0716:一看怎么昨天卡没打,原来昨天做的第一题不是每日一题,麻了 n很小,200,那么 先排序 ,然后弄一个 双指针开双循环 l,r ,确定每个组合的最大数字-数字4和最

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

    链接: 1388. 3n 块披萨 题意: 一个长度3n的环,选n次数字,每次选完以后相邻的数字会消失,求选取结果最大值 解: 这波是~~(ctrl)CV工程师了~~ 核心思想是选取 n个不相邻 的元素一定 合法 ,我推不出来,猜一猜倒是可以O.o DP[i][j] 表示从 [0,i] 中选取 j 个数字的最大值 初始

    2024年02月12日
    浏览(35)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包