zoukankan      html  css  js  c++  java
  • 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;
        }
    };
  • 相关阅读:
    Spring系列-JDBC实例
    postman-记录cookies信息
    根据URL获取参数值得出json结果集,对外给一个接口让别人调用
    linux 软硬链接
    第一个shell程序
    Argparse简易教程
    SQLAlchemy 教程 —— 基础入门篇
    人机对战初体验—四子棋游戏
    python的Flask 介绍
    python的项目结构
  • 原文地址:https://www.cnblogs.com/zzw-/p/13411729.html
Copyright © 2011-2022 走看看