【Day29 LeetCode】动态规划DP

一、动态规划DP

1、不同路径 62

首先是dp数组,dp[i][j]表示从起点(0, 0)到达当前位置(i, j)的路径数,转移方程从只能向下和向右移动可知,初始化边界可直观推出第一行和第一列上的位置只有一条路径。

CPP 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        vector<vector<int>> dp(m, vector<int>(n));
        // 初始化
        for(int i=0; i<m; ++i)
            dp[i][0] = 1;
        for(int i=0; i<n; ++i)
            dp[0][i] = 1;
        // 循环
        for(int i=1; i<m; ++i)
            for(int j=1; j<n; ++j)
                dp[i][j] = dp[i-1][j] + dp[i][j-1];
        return dp[m-1][n-1];
    }
};

空间复杂度优化,采用一维数组来记录一行的状态,通过循环来更新dp[i-1][j]的值。

CPP 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        vector<int> dp(n, 1);
        for(int i=1; i<m; ++i)
            for(int j=1; j<n; ++j)
                dp[j] += dp[j-1];
        return dp[n-1];
    }
};

2、不同路径Ⅱ 63

这题相比于上一次只是多了障碍物的情况,遇到障碍物则路径为0。

CPP 复制代码
class Solution {
public:
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        int m = obstacleGrid.size(), n = obstacleGrid[0].size();
        vector<vector<int>> dp(m, vector<int>(n));
        // 初始化
        for(int i=0; i<m; ++i){
            if(obstacleGrid[i][0]==0)
                dp[i][0] = 1;
            else
                break;
        }
        for(int i=0; i<n; ++i){
            if(obstacleGrid[0][i]==0)
                dp[0][i] = 1;
            else
                break;
        }
        // 循环
        for(int i=1; i<m; ++i)
            for(int j=1; j<n; ++j)
                dp[i][j] = (obstacleGrid[i][j]==0? dp[i-1][j] + dp[i][j-1] : 0);
        return dp[m-1][n-1];
    }
};

同样的空间复杂度优化

CPP 复制代码
class Solution {
public:
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        int m = obstacleGrid.size(), n = obstacleGrid[0].size();
        vector<int> dp(n+1);
        dp[1] = (obstacleGrid[0][0]==0);
        for(int i=0; i<m; ++i)
            for(int j=0; j<n; ++j)
                dp[j+1] = (obstacleGrid[i][j]==1 ? 0 : (dp[j]+dp[j+1]));
        return dp[n];
    }
};

3、整数拆分 343

待更新...

CPP 复制代码

4、不同的二叉搜索树 96

待更新...

CPP 复制代码

二、写在后面

后续会出一期专门讲二维DP空间优化的博客,敬请期待。

相关推荐
霜绛11 分钟前
机器学习笔记(四)——聚类算法KNN、Kmeans、Dbscan
笔记·算法·机器学习·kmeans·聚类
晨非辰1 小时前
#C语言——学习攻略:深挖指针路线(三)--数组与指针的结合、冒泡排序
c语言·开发语言·数据结构·学习·算法·排序算法·visual studio
zzywxc7871 小时前
编程算法在金融、医疗、教育、制造业等领域的落地案例
人工智能·算法·金融·自动化·copilot·ai编程
zzywxc7871 小时前
编程算法在金融、医疗、教育、制造业的落地应用。
人工智能·深度学习·算法·机器学习·金融·架构·开源
conkl2 小时前
构建 P2P 网络与分布式下载系统:从底层原理到安装和功能实现
linux·运维·网络·分布式·网络协议·算法·p2p
Shan12052 小时前
递归算法的一些具体应用
算法
paopaokaka_luck4 小时前
婚纱摄影管理系统(发送邮箱、腾讯地图API、物流API、webSocket实时聊天、协同过滤算法、Echarts图形化分析)
vue.js·spring boot·后端·websocket·算法·echarts
愚戏师5 小时前
机器学习(重学版)基础篇(算法与模型一)
人工智能·算法·机器学习
OEC小胖胖7 小时前
渲染篇(二):解密Diff算法:如何用“最少的操作”更新UI
前端·算法·ui·状态模式·web
找不到、了7 小时前
Java排序算法之<归并排序>
算法·排序算法