Leetcode-动态规划

198. 打家劫舍 - 力扣(LeetCode)

首先用回溯的方法来思考 虽然会超时但是这是后面记忆化搜索的根基

从最后一家开始打 有两种情况 要么打 要么不打 打或者不打 都有可能产生最终答案

因此想到可以用回溯 在回溯的过程用max记录最大值 最后返回

但是这种写法其实重复计算了很多次

例如一开始选择4不打3不打 然后进入子问题2计算得出这种走法的最大值 但是另一种情况 一开始选4 然后选2 也就是右边的子树 其实和前面43都不选后选2的子树是一模一样的 因此我们可以将这个计算后的答案记录下来 如果一种走法被记录过了就不再递归 这样就可以降低时间复杂度

java 复制代码
class Solution {
    int []nums;
    public int rob(int[] nums) {
        this.nums=nums;
        int n=nums.length;
        return dfs(n-1);
    }
    public int dfs(int i){
        if(i<0)return 0;
        int ans=Math.max(dfs(i-1),dfs(i-2)+nums[i]);
        return ans;
    }
}
java 复制代码
class Solution {
    public int rob(int[] nums) {
      int n=nums.length;
      int []f=new int [n+2];
      for(int i=0;i<n;i++){
        f[i+2]=Math.max(f[i+1],f[i]+nums[i]);
      }
      return f[n+1];
    }
}

递推写法:

将回溯的写法一比一翻译

用for循环代替递归

用两个0优先赋值

最后由于前面填充了两个0 答案就是i=n-1 再+2 n+1

java 复制代码
class Solution {
    public int rob(int[] nums) {
      int n=nums.length;
      int []f=new int [n+2];
      for(int i=0;i<n;i++){
        f[i+2]=Math.max(f[i+1],f[i]+nums[i]);
      }
      return f[n+1];
    }
}
相关推荐
铉铉这波能秀15 小时前
LeetCode Hot100数据结构背景知识之字典(Dictionary)Python2026新版
数据结构·python·算法·leetcode·字典·dictionary
蜡笔小马15 小时前
10.Boost.Geometry R-tree 空间索引详解
开发语言·c++·算法·r-tree
我是咸鱼不闲呀15 小时前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
唐梓航-求职中15 小时前
编程-技术-算法-leetcode-288. 单词的唯一缩写
算法·leetcode·c#
仟濹16 小时前
【算法打卡day3 | 2026-02-08 周日 | 算法: BFS】3_卡码网99_计数孤岛_BFS | 4_卡码网100_最大岛屿的面积DFS
算法·深度优先·宽度优先
Ll130452529816 小时前
Leetcode二叉树part4
算法·leetcode·职场和发展
颜酱16 小时前
二叉树遍历思维实战
javascript·后端·算法
宝贝儿好16 小时前
第二章: 图像处理基本操作
算法
小陈phd16 小时前
多模态大模型学习笔记(二)——机器学习十大经典算法:一张表看懂分类 / 回归 / 聚类 / 降维
学习·算法·机器学习
@––––––16 小时前
力扣hot100—系列4-贪心算法
算法·leetcode·贪心算法