• LeetCode 931 下降路径最小和


    题目描述链接:https://leetcode-cn.com/problems/minimum-falling-path-sum/

    解题思路:动态规划。(1)状态表示:dp[i][j]表示到达A[i][j]节点的最小路径。

                                        (2)边界确定:dp[0][j]=A[0][j]即第一行的值为即为本身值,因为第一行为开始。

                                        (3)状态转移方程:dp[i][j]=min(dp[i-1][j-1],dp[i-1][j],dp[i-1][j+1])+A[i][j],这里由于是从上到下,且最多跨越一列,当然还要考虑越界问题,如果j=0,那么dp[i][j-1]就不用考虑了,当然此时

                                                  dp[i][j-1]也不存在,另外j=len-1时也时如此。具体实现可以参考下文代码

    最后遍历最后一行的dp[len-1][j],寻找最小值返回即可。

    LeetCode C++解题参考代码如下:

    class Solution {
    public:
        int minFallingPathSum(vector<vector<int>>& A) {
            int minum=0xfffffff;
            int len=A.size();
            if(len==0){
                return 0;
            }
            int dp[len][len];
            for(int i=0;i<len;i++){
                for(int j=0;j<len;j++){
                    if(i==0){
                        dp[i][j]=A[i][j];
                    }
                    else {
                        if(j-1>=0&&j+1<len){
                            int temp=min(dp[i-1][j],dp[i-1][j-1]);
                            dp[i][j]=min(temp,dp[i-1][j+1])+A[i][j];
                        }
                        
                        else if(j-1>=0){
                            dp[i][j]=min(dp[i-1][j-1],dp[i-1][j])+A[i][j];
                        }
                        else if(j+1<len){
                            dp[i][j]=min(dp[i-1][j+1],dp[i-1][j])+A[i][j];
                        }
                        else{
                            dp[i][j]=dp[i-1][j]+A[i][j];
                        }
                    }
                    
                   
                }
            }
            for(int i=0;i<len;i++){
                minum=min(dp[len-1][i],minum);
            }
            return minum;
        }
    };
  • 相关阅读:
    【学习笔记 2】单调队列 & 单调栈
    【学习笔记 1】快速幂
    题解P1151
    题解 P6161【[Cnoi2020]高维】
    不知道叫啥的题目1
    神秘题目1
    5.30 模拟赛赛后总结
    矩阵乘法加速图上问题专题总结
    点分治&点分树 复习
    5.26赛后总结
  • 原文地址:https://www.cnblogs.com/zzw-/p/13411729.html
Copyright © 2020-2023  润新知