动态规划不同维度分析leetcode198.打家劫舍问题

java 复制代码
class Solution {
    public int rob(int[] nums) {
        return robByTwoDim(nums);
    }

    // 二维dp算法 一层for训练
    public int robByTwoDim(int[] nums){
        int[][] dp = new int[2][nums.length + 1];
        for(int j = 1; j <= nums.length; j++){
            dp[0][j] = nums[j - 1] + dp[1][j - 1];   // 偷,那么再去上一个不偷的最大值
            dp[1][j] = Math.max(dp[0][j - 1], dp[1][j - 1]);  // 不偷,在上一个偷和不偷之间选择一个
        }
        return Math.max(dp[0][nums.length], dp[1][nums.length]);
    }

    // 一维dp算法 两层for循环
    public int robByOneDim(int[] nums) {
        int[] dp = new int[nums.length + 1];
        int max = 0;
        for(int i = 1; i <= nums.length; i++){
            for(int j = 0; j < i - 1; j++){  // i - 1 保证是当前可以偷
                dp[i] = Math.max(dp[i], dp[j]);
            }
            dp[i] = dp[i] + nums[i - 1];
            if(dp[i] > max){
                max = dp[i];
            }
        }
        return max;
    }
}

该题分别利用一维和二维dp数组进行求解。一般来说,遇到递归时,先思考一维再思考二维,对于复杂的问题,可直接先对二维进行思考。一维一般注意点:(1)dp数组中当前索引对应存储空间存储的是从下标0到当前索引最优值,还是必须考虑当前索引的次优值,对于该题中第一种解法,当前房间必须偷的最优值。全局最优可以利用max临时变量来进行记录。(2)当计算递推公式无法利用某一个或者某几个推导时,可以考虑,从第一个元素开始进行遍历。针对该题,如果当前房间必偷,dp数组当前索引推导式可在从0-(i-1)最大值加当前房间现金数。二维一般要注意五要素,特别是遍历顺序,可以思考对dp[i][j]中j进行遍历,正如该题,也可以按照二维数组遍历顺序进行遍历,当前值由(i - m (||、&&) j - n)s等所得。最后,为了方便编码,可以为边界预留空间,比如,本解法中dp数组长度都加了1。

相关推荐
故事和你911 小时前
洛谷-【动态规划1】动态规划的引入2
开发语言·数据结构·c++·算法·动态规划·图论
重生之我是Java开发战士1 小时前
【动态规划】背包问题:完全背包,二位费用的背包问题,似包非包
算法·动态规划
LabVIEW开发1 小时前
LabVIEW实现FDTD 电磁仿真
算法·labview·labview知识·labview功能·labview程序
Together_CZ2 小时前
DTSemNet :Vanilla Gradient Descent for Oblique Decision Trees——用于倾斜决策树的普通梯度下降
算法·决策树·机器学习·vanilla·gradient·dtsemnet·用于倾斜决策树的普通梯度
一条大祥脚2 小时前
ABC459 贪心构造|树形DP|组合数学|贪心|单调栈|势能|前缀和
算法·深度优先
灰灰勇闯IT2 小时前
DeepEP:MoE 推理的 AllToAll 通信瓶颈怎么解
算法·cann
一行代码一行诗++2 小时前
goto语句
java·开发语言·算法
汉克老师3 小时前
GESP5级C++考试语法知识(十七、二分算法提高篇(二))
c++·算法·二分算法·gesp5级·gesp五级·二分算法易错点
叶小鸡3 小时前
小鸡玩算法-力扣HOT100-动态规划(下)
算法·leetcode·动态规划
信奥胡老师4 小时前
B3968 [GESP202403 五级] 成绩排序
数据结构·算法