64、最小路径和

题目:

解答:

简单dp。

定义:dpij为到达(i,j)所需要的最短路程

初始化:dp00=grid00,同时对第一行和第一列的,第i个就是前i个之和加上自身

递归:dpij=min(dpi-1j,dpij-1)+gridij,也就是从上面到达或者从左边到达

空间复杂度O(mn),m为grid行数,n为grid列数,作空间优化

vector<vector<int>> dp(m,vector<int>(2)) m行2列的vector 降低空间复杂度为m(这里也可以先写个if,判断m和n大小,来决定是m行2列还是m列2行,不影响时间复杂度)

按照一列一列来遍历,修改初始化条件,先初始化第一列,然后从第二列开始,dp01单独计算,dpj1按照上述递归式子的算法计算。一列遍历完成后,用dpm0=dpm1来存储状态,继续扫描下一列。最后return dpm-11即可

cpp 复制代码
class Solution {
public:
    int minPathSum(vector<vector<int>>& grid) {
        int m = grid.size();
        int n = grid[0].size();
        if(n==1) {
            int ans = 0;
            for(int i=0;i<m;i++)    
                ans+=grid[i][0];
            return ans;
        }
        vector<vector<int>> dp(m,vector<int>(2));
        //dp[j][1]=min(dp[j][0],dp[j-1][1])+grid[j][i]
        dp[0][0]=grid[0][0];
        for(int i=1;i<m;i++)
            dp[i][0]=dp[i-1][0]+grid[i][0];
        for(int i=1;i<n;i++){
            for(int j=0;j<m;j++){
                if(j==0)
                    dp[j][1]=grid[j][i]+dp[j][0];
                else
                    dp[j][1]=min(dp[j-1][1],dp[j][0])+grid[j][i];  
            }
            for(int j=0;j<m;j++)
                dp[j][0]=dp[j][1];
        }
        return dp[m-1][1];
    }
};

时间复杂度O(mn)

空间复杂度O(m)

相关推荐
珂朵莉MM7 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro1 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort1 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域2 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS2 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
小白兔奶糖ovo3 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll3 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程3 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan3 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h4 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash