算法训练营day39

一、不同路径
  1. 使用memo数组保存已经计算过的位置,避免重复计算
  2. 明确dp数组的含义,到达某点时的不同路径数量
  3. 明确状态转移方程,进行递归计算
  4. 注意索引偏移1位,
java 复制代码
class Solution {
    //备忘录    
    int[][] memo;

    public int uniquePaths(int m, int n) {
        memo = new int[m][n];
        return dp(m-1, n-1);
    }

    //dp定义:从(0,0) 到 (x,y) 有dp(x,y)条路径
    int dp(int x, int y){
        //base case
        if(x == 0 || y == 0){
            return 1;
        }
        if(x < 0 || y < 0){
            return 0;
        }
        //避免冗余计算
        if(memo[x][y] > 0){
            return memo[x][y];
        }
        //状态转移方程
        memo[x][y] = dp(x-1, y) + dp(x, y-1);
        return memo[x][y];
    }
}
二、不同路径2
  1. 创建新的二维数组避免重复计算
  2. 初始化dp数组,动态规划创建数组大小需要+1,那么判断对应的原数组时需要减去1,并且for循环初始变量的值也为1
java 复制代码
class Solution2 {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;
        // 数组索引偏移一位,dp[0][..] dp[..][0] 代表 obstacleGrid 之外
        // 定义:到达 obstacleGrid[i][j] 的路径条数为 dp[i-1][j-1]
        int[][] dp = new int[m + 1][n + 1];
        // base case:如果没有障碍物,起点到起点的路径条数就是 1
        dp[1][1] = obstacleGrid[0][0] == 1 ? 0 : 1;

        for (int i = 1; i <= m; i++) {
            for (int j = 1; j <= n; j++) {
                if (i == 1 && j == 1) {
                    // 跳过 base case
                    continue;
                }
                if (obstacleGrid[i - 1][j - 1] == 1) {
                    // 跳过障碍物的格子
                    continue;
                }
                dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
            }
        }
        // 返回到达 obstacleGrid[m-1][n-1] 的路径数量
        return dp[m][n];
    }
}
相关推荐
李慕婉学姐6 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
じ☆冷颜〃6 小时前
黎曼几何驱动的算法与系统设计:理论、实践与跨领域应用
笔记·python·深度学习·网络协议·算法·机器学习
数据大魔方6 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
POLITE36 小时前
Leetcode 23. 合并 K 个升序链表 (Day 12)
算法·leetcode·链表
楚来客7 小时前
AI基础概念之八:Transformer算法通俗解析
人工智能·算法·transformer
Echo_NGC22377 小时前
【神经视频编解码NVC】传统神经视频编解码完全指南:从零读懂 AI 视频压缩的基石
人工智能·深度学习·算法·机器学习·视频编解码
会员果汁7 小时前
leetcode-动态规划-买卖股票
算法·leetcode·动态规划
奋进的芋圆8 小时前
Java 延时任务实现方案详解(适用于 Spring Boot 3)
java·spring boot·redis·rabbitmq
橘颂TA8 小时前
【剑斩OFFER】算法的暴力美学——二进制求和
算法·leetcode·哈希算法·散列表·结构与算法
sxlishaobin8 小时前
设计模式之桥接模式
java·设计模式·桥接模式