408算法题leetcode--第35天

63. 不同路径 II

题目地址63. 不同路径 II - 力扣(LeetCode)

题解思路:dp

时间复杂度:O(n * m)

空间复杂度:O(n * m)

代码:

cpp 复制代码
class Solution {
public:
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        // dp[][]: 走到该位置的数量
        // 转移:dp[i][j] = dp[i - 1][j] + dp[i][j - 1], 0
        // 初始化:第一行 = dp[i - 1][0], 0;同理第一列
        // 顺序:左右,上下
        vector<vector<int>>dp(obstacleGrid.size(), vector<int>(obstacleGrid[0].size(), 0));
        int n = obstacleGrid.size(), m = obstacleGrid[0].size();
        for(int i = 0; i < n && obstacleGrid[i][0] == 0; i++){  // 如果有障碍物就终止循环
            dp[i][0] = 1;
        }
        for(int j = 0; j < m && obstacleGrid[0][j] == 0; j++){
            dp[0][j] = 1;
        }
        for(int i = 1; i < n; i++){
            for(int j = 1; j < m; j++){
                dp[i][j] = obstacleGrid[i][j] == 1 ? 0 : dp[i - 1][j] + dp[i][j - 1];
            }
        }
        return dp[n - 1][m - 1];
    }
};

343. 整数拆分

题目地址343. 整数拆分 - 力扣(LeetCode)

题解思路:dp

时间复杂度:O(n^2)

空间复杂度:O(n)

代码:

cpp 复制代码
class Solution {
public:
    int integerBreak(int n) {
        // dp[]: 拆i的最大乘积,如dp[10] = 36
        // 递推:i可以拆为j + (i - j);dp[i] = max(dp[i], max(j * (i - j), j * dp[i - j]))
        // 初始化:dp[2] = 1
        // 顺序:左到右
        vector<int>dp(n + 1);
        dp[2] = 1;
        for(int i = 3; i <= n; i++){
            for(int j = 1; j <= i/2; j++){  // 遍历到i / 2即可
                dp[i] = max(dp[i], max(j * (i - j), j * dp[i - j]));
            }
        }
        return dp[n];
    }
};
相关推荐
欧克小奥8 小时前
Floyd判圈算法(Floyd Cycle Detection Algorithm)
算法·floyd
熬了夜的程序员9 小时前
【LeetCode】83. 删除排序链表中的重复元素
算法·leetcode·链表
胖咕噜的稞达鸭10 小时前
AVL树手撕,超详细图文详解
c语言·开发语言·数据结构·c++·算法·visual studio
YSRM10 小时前
Leetcode+Java+图论II
java·leetcode·图论
熊猫钓鱼>_>10 小时前
Rust语言特性深度解析:所有权、生命周期与模式匹配之我见
算法·rust·软件开发·函数·模式匹配·异步编程·质量工具
芒果量化10 小时前
Optuna - 自动调参利器&python实例
开发语言·python·算法·机器学习
麦麦大数据10 小时前
D025 摩托车推荐价格预测可视化系统|推荐算法|机器学习|预测算法|用户画像与数据分析
mysql·算法·机器学习·django·vue·推荐算法·价格预测
CoovallyAIHub11 小时前
IDEA研究院发布Rex-Omni:3B参数MLLM重塑目标检测,零样本性能超越DINO
深度学习·算法·计算机视觉
蒙奇D索大11 小时前
【操作系统】408操作系统核心考点精讲:宏内核、微内核与外核架构全解析
笔记·考研·架构·改行学it
豐儀麟阁贵11 小时前
4.4数组的基本操作
java·开发语言·数据结构·算法